欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何用python獲取EXCEL文件內(nèi)容并保存到DBC

 更新時(shí)間:2023年12月18日 11:46:31   作者:逸埃  
很多時(shí)候,使用python進(jìn)行數(shù)據(jù)分析的第一步就是讀取excel文件,下面這篇文章主要給大家介紹了關(guān)于如何用python獲取EXCEL文件內(nèi)容并保存到DBC的相關(guān)資料,需要的朋友可以參考

關(guān)鍵詞

==python、excel、DBC、openpyxl ==

平臺(tái)說(shuō)明

項(xiàng)目Value
python版本3.6

背景

在搭建自動(dòng)化測(cè)試平臺(tái)的時(shí)候經(jīng)常會(huì)提取DBC文件中的信息并保存為excel或者其他文件格式,用于自動(dòng)化測(cè)試。本文介紹了如何用python3.6實(shí)現(xiàn)獲取EXCEL文件內(nèi)容并保存到DBC。

所需庫(kù)

1.canmatrix:需要它庫(kù)來(lái)解析 DBC 文件,它提供了對(duì) Controller Area Network (CAN) 數(shù)據(jù)的解析功能,包括 DBC 文件的支持。

2.openpyxl :是一個(gè)用于讀寫 Excel 文件的 Python 庫(kù)。

實(shí)現(xiàn)過(guò)程

方法1.

1.安裝相關(guān)庫(kù)

pip install openpyxl canmatrix

2.代碼實(shí)現(xiàn)

from openpyxl import load_workbook
import canmatrix

class MyDBC_Obj:
    def __init__ (self,dbc_path,excel_path):
        self.name = "self"
        self.sheet = ""
        self.dbc = ""
        self.dbc_path = dbc_path
        self.excel_path = excel_path

    def read_excel(self):
        workbook = load_workbook(filename = self.excel_path)
        self.sheet = workbook.active

    def generate_dbc(self):
        self.dbc = canmatrix.CanMatrix()
        self.dbc.add_global_defines("BusType","STRING")
        self.dbc.add_define_default("BusType","CAN")
        # 報(bào)文發(fā)送類型屬性以及默認(rèn)值
        self.dbc.add_frame_defines("GenMsgSendType", 'ENUM "Cyclic", "Event"' )
        self.dbc.add_define_default("GenMsgSendType", "Cyclic")
        self.dbc.add_frame_defines("GenMsgCycleTime", 'INT 0 65535')
        self.dbc.add_define_default("GenMsgCycleTime", "0")

    def write_dbc(self):
        self.read_excel()
        self.generate_dbc()
        ecu_obj = canmatrix.Ecu(self.sheet.cell(1,29).value)
        ecu_obj.name = self.sheet.cell(1,29).value
        
        self.dbc.add_ecu(ecu_obj)
        for i in range(2,self.sheet.max_row+1):
            if self.sheet.cell(row=i,column=1).value == None:
                self.sheet.cell(row=i,column=1).value = self.sheet.cell(row=i-1,column=1).value
                self.sheet.cell(row=i,column=2).value = self.sheet.cell(row=i-1,column=2).value
                self.sheet.cell(row=i,column=3).value = self.sheet.cell(row=i-1,column=3).value
                self.sheet.cell(row=i,column=4).value = self.sheet.cell(row=i-1,column=4).value
                self.sheet.cell(row=i,column=5).value = self.sheet.cell(row=i-1,column=5).value
                self.sheet.cell(row=i,column=6).value = self.sheet.cell(row=i-1,column=6).value
        message_name = ""
        message_id = 0
        message_length = 0
        message_type_is_fd = False
        message_type_is_extended = False
        message_cycle = 0
        message_recive = ""
        frame_obj = canmatrix.Frame()
        signal_obj=canmatrix.Signal()
        for row in self.sheet.iter_rows(min_row=3,values_only=True):            
            signal_name = row[6]
            if signal_name != None:
                signal_obj.name = row[6]
                message_name = row[0]
                message_id = int(row[2],16)
                if row[11] != None:
                    signal_obj.start_bit = int(row[11])
                else:
                    signal_obj.start_bit = 0
                signal_obj.size = int(row[13])
                if row[9] == "Motorola":
                    signal_obj.is_little_endian = False
                else:
                    signal_obj.is_little_endian = True
                signal_obj.initial_value = int(row[21])
                signal_obj.add_attribute("GenSigStartValue",signal_obj.initial_value)
                signale_sendtype = 0
                if row[12] == "Cycle":
                    signale_sendtype = 0
                else:
                    signale_sendtype = 2
                signal_obj.add_attribute("GenSigSendType",signale_sendtype)
                if row[14] == "unsigned":
                    signal_obj.is_float = False
                    signal_obj.is_signed = False
                elif row[14] == "signed":
                    signal_obj.is_float = False
                    signal_obj.is_signed = True
                else:
                    signal_obj.is_float = True
                    signal_obj.is_signed = False

                signal_obj.min = float(row[17])
                signal_obj.max = float(row[18])
                signal_obj.factor = float(row[15])
                signal_obj.offset = float(row[16])
                if row[23] != None:
                    signal_obj.unit = row[23]
                if row[28] == "RX":
                    signal_obj.add_receiver(ecu_obj.name)
                elif row[28] == "TX":
                    message_recive = ecu_obj.name

                message_sig_group_name = row[8]
                if  message_sig_group_name != None:
                    signalGroups = frame_obj.signal_group_by_name(message_sig_group_name)
                    if signalGroups == None:
                        frame_obj.add_signal_group(message_sig_group_name,1,signal_obj.name)
                    else:
                        signalGroups.add_signal(signal_obj)

                if row[24] != None:
                    sigvalue = row[24]
                    st=sigvalue.split("\n")
                    for i in st:
                        if i == "":
                            st.remove(i)
                    d = dict(x.split(":") for x in st)
                    for k, v in d.items():
                        signal_obj.add_values(k,v)             
                frame_obj.add_signal(signal_obj)
                #*********** frame type set ***************
                signal_obj=canmatrix.Signal()

                if row[5] != None:
                    message_length = int(row[5])
                else:
                    message_length = 0
                if row[4] != None:
                    message_cycle = int(row[4])
                if row[1] == "CAN standard":
                    message_type_is_fd = False
                    message_type_is_extended = False
                elif row[1] == "CANFD standard":
                    message_type_is_fd = True
                    message_type_is_extended = False
                elif row[1] == "CAN extended":
                    message_type_is_extended = True
                    message_type_is_fd = False
                elif row[1] == "CANFD extended":
                    message_type_is_extended = True
                    message_type_is_fd = True
            else:
                frame_obj.name = message_name
                frame_obj.size = message_length
                frame_obj.arbitration_id.id = message_id
                frame_obj.cycle_time = message_cycle
                frame_obj.is_fd = message_type_is_fd
                frame_obj.is_j1939 = message_type_is_extended
                if message_recive!= "":
                    frame_obj.add_transmitter(ecu_obj.name)
                self.dbc.add_frame(frame_obj)
                message_name = ""
                message_id = 0
                message_length = 0
                message_type = False
                message_recive = ""
                signalGroups = []
                frame_obj = canmatrix.Frame()

        # 導(dǎo)出到DBC文件
        
        file_out = open(self.dbc_path, "wb")
        canmatrix.formats.dbc.dump(self.dbc,file_out,dbcExportEncoding='utf-8')
        file_out.close()

if __name__ == "__main__":
    dbc_file_path = "excel.dbc"  # Replace with the actual DBC file path
    excel_file_path = "dbc.xlsx"  # Replace with the desired Excel output path
    MyDbc = MyDBC_Obj(dbc_file_path,excel_file_path)
    MyDbc.write_dbc()

總結(jié) 

到此這篇關(guān)于如何用python獲取EXCEL文件內(nèi)容并保存到DBC的文章就介紹到這了,更多相關(guān)python獲取EXCEL內(nèi)容保存DBC內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python center()函數(shù)使用方法詳解

    Python center()函數(shù)使用方法詳解

    在python中,center()返回一個(gè)原字符居中,并默認(rèn)使用空格填充至長(zhǎng)度width返回新字符串,默認(rèn)填充字符為空格,本就將通過(guò)代碼示例給大家簡(jiǎn)單的介紹一下Python center()函數(shù)是的使用方法,感興趣的同學(xué)跟著小編一起來(lái)看看吧
    2023-07-07
  • python字典和JSON格式的轉(zhuǎn)換方式

    python字典和JSON格式的轉(zhuǎn)換方式

    這篇文章主要介紹了python字典和JSON格式的轉(zhuǎn)換方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • 解決python flask中config配置管理的問(wèn)題

    解決python flask中config配置管理的問(wèn)題

    今天小編就為大家分享一篇解決python flask中config配置管理的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-07-07
  • Python動(dòng)態(tài)演示旋轉(zhuǎn)矩陣的作用詳解

    Python動(dòng)態(tài)演示旋轉(zhuǎn)矩陣的作用詳解

    一個(gè)矩陣我們想讓它通過(guò)編程,實(shí)現(xiàn)各種花樣的變化怎么辦呢?下面這篇文章主要給大家介紹了關(guān)于Python動(dòng)態(tài)演示旋轉(zhuǎn)矩陣的作用,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-12-12
  • python的help函數(shù)如何使用

    python的help函數(shù)如何使用

    在本篇文章里小編給大家整理的是關(guān)于python的help函數(shù)的相關(guān)用法和知識(shí)點(diǎn)總結(jié),需要的朋友們可以學(xué)習(xí)下。
    2020-06-06
  • 簡(jiǎn)單了解python反射機(jī)制的一些知識(shí)

    簡(jiǎn)單了解python反射機(jī)制的一些知識(shí)

    這篇文章主要介紹了簡(jiǎn)單了解python反射機(jī)制的一些知識(shí),反射機(jī)制就是在運(yùn)行時(shí),動(dòng)態(tài)的確定對(duì)象的類型,并可以通過(guò)字符串調(diào)用對(duì)象屬性、方法、導(dǎo)入模塊,是一種基于字符串的事件驅(qū)動(dòng)。,需要的朋友可以參考下
    2019-07-07
  • python小程序?qū)崿F(xiàn)刷票功能詳解

    python小程序?qū)崿F(xiàn)刷票功能詳解

    這篇文章主要介紹了python小程序?qū)崿F(xiàn)刷票功能詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-07-07
  • 在python里面運(yùn)用多繼承方法詳解

    在python里面運(yùn)用多繼承方法詳解

    在本篇文章中小編給各位分享的是關(guān)于在python里面運(yùn)用多繼承方法以及知識(shí)點(diǎn)總結(jié),有興趣的朋友們可以學(xué)習(xí)下。
    2019-07-07
  • Python Flask-web表單使用詳解

    Python Flask-web表單使用詳解

    這篇文章主要為大家詳細(xì)介紹了Python Flask-web表單的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • pandas刪除指定行詳解

    pandas刪除指定行詳解

    這篇文章主要介紹了pandas刪除指定行的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04

最新評(píng)論