使用python制作一個為hex文件增加版本號的腳本實例
更新時間:2019年06月12日 20:14:38 作者:北極熊的脖子
今天小編就為大家分享一篇使用python制作一個為hex文件增加版本號的腳本實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
最近公司一個項目需要用到IAP升級,要求將APP的版本號在hex文件添加,于是嘗試用python寫一個腳本,運行之后可以自動增加版本號,并且日期都是當(dāng)天的
import re import time #獲取日期的數(shù)據(jù)及校驗和 year = int(time.strftime("%y", time.localtime())) month = int(time.strftime("%m", time.localtime())) date = int(time.strftime("%d", time.localtime())) checkofsum = 512 - year - month - date - 4 - 255 #打開文件,以二進制打開文件方便seek函數(shù)的第一個參數(shù)可以取負(fù)數(shù) #從而獲取倒數(shù)第二行的數(shù)據(jù)(整個數(shù)據(jù)只有最后兩行的數(shù)據(jù)數(shù)固定的) f1 = open("E:\資料\K256(K211)\K256(從機部分)\APP\Objects\k256_slave.hex", "rb") f2 = open("E:\資料\K256(K211)\K256(從機部分)\APP\Objects\k256_slave_1.hex", "w") f1.seek(-34, 2) str = f1.readline() #解碼并把空格去掉(將b''去掉,多出來的一行空格去掉) #str為倒數(shù)第二行數(shù)據(jù) str = str.decode("utf-8").rstrip() f1.close() #如何以二進制方式讀取文件,即使解碼去空格,jflash還是無法讀取創(chuàng)建的hex文件 f1 = open("E:\資料\K256(K211)\K256(從機部分)\APP\Objects\k256_slave.hex", "r") #在倒數(shù)第二行前加上版本號04FF000011091A00C9 #04表示本行數(shù)據(jù)的長度 FF00表示本行數(shù)據(jù)的起始地址 00表示數(shù)據(jù)類型 #11091A表示2017年9月26號 00表示app模式 C9校驗和(前面所有數(shù)據(jù)總和取低八位再用0x100去減所得的結(jié)果) f2.write(f1.read().replace(str, ":04FF0000%02X%02X%02X00%02X\r\n"%(year, month, date, checkofsum) + str)) f1.close() f2.close()
修改前的APP的hex文件(地址最終在800B290)
修改后的app文件(地址最終在800FF00)
以上這篇使用python制作一個為hex文件增加版本號的腳本實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
PyCharm導(dǎo)入python項目并配置虛擬環(huán)境的教程詳解
這篇文章主要介紹了Pycharm導(dǎo)入python項目并配置虛擬環(huán)境的教程,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-10-10python 集合 并集、交集 Series list set 轉(zhuǎn)換的實例
今天小編就為大家分享一篇python 集合 并集、交集 Series list set 轉(zhuǎn)換的實例。具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-05-05Python使用wxPython和PyMuPDF提取PDF頁面指定頁數(shù)的內(nèi)容
在本篇博客中,我們將探討如何使用wxPython和PyMuPDF庫創(chuàng)建一個簡單的Bokeh應(yīng)用程序,用于選擇PDF文件并提取指定頁面的內(nèi)容,并將提取的內(nèi)容顯示在文本框中,需要的朋友可以參考下2023-08-08