python模塊安裝、串口操作、字節轉換、exe生成、CRC計算
背景:
第一次采用python制作小工具,已安裝版本2.7.9的python;
1.pyCharm license注冊問題
采用License server, license server address:(http://xidea.online)
2.pyCharm下調試
在文件下新建項目,然后再新建文件,就可以使用集成調試了;
3.串口操作--外部包
可通過在cmd下直接運行:pip install pyserial
python -m pip install pyserial 也可以,如果pip路徑並沒有加入環境變量中
4.crc效驗---外部包
可通過windows下cmd運行:pip install crcmod
5.byte與ASCII碼轉化--內部包binascii
6.python生成EXE---外部包PyInstaller
7.串口操作API用法
(1)打開串口
API---Serial("COM19",115200)
[注意]:這邊有看到第一個參數有人寫0(對應COM1),但提示輸入錯誤,要求輸入字符串類型,輸入'0'依然不行;
(2)讀操作
API---read(n)
需要提前知道返回字符串長度
返回str
API---readline()
讀取一行,以OA 或者OD結束
返回str,str里面的值為ASCII碼的字符形式,比如0X30需要寫成'3';對其處理,需要轉化成十六進制;
API---readlines()
讀取多行,
返回list
還有其它方案說是配合:
API---inwaiting()
返回接收的字符串長度,再把這個值給read()來讀取出來;
測試沒成功;
API---readall()
測試沒成功;
(3)寫操作
API---write(data)
data為str,str里面的值為ASCII碼的字符形式的,比如0X33需要寫成'3';方法后面介紹;
8.byte轉化為ASCII
API---unhexlify(data)
將byte型(16進制的值);轉化為ASCII字符形式的,如0X33代表字符'3';用於組包后將數據轉化為字符型,再傳輸;
API--hexlify(data)
將ASCII字符數據,轉化為byte(十六進制形式的),比如將接收的數據,進行處理后,再進行其它后續處理,如crc效驗等;
9.crc效驗
API--mkCrcFun(0x11021,rev=False,initCrc=0x0000,xorOut=0x0000)
0x11021代表CRC-16 XMODEM(X16+X12+X5+1)
例子:
crc16_Xmodem = crcmod.mkCrcFun(0x11021,rev=False,initCrc=0x0000,xorOut=0x0000)
readFun = '68020000'
readCrcOUT = hex(crc16_cmodem(unhexlify(readFun)))
輸出來的值為0x1234之類的,str類型
10.PyInstaller
python下將py文件編譯成exe形式的方式有兩種:PyInstaller和py2exe;
安裝方式:cmd下輸入:pip install PyInstaller
(1)操作方式
在存放.py的文件夾下打開當前路徑的cmd,然后pyinstaller -F 文件.py
[注意]:
1.pip install PyInstaller中千萬要注意大小寫,看了網上很多都是pyinstaller,然后一直安裝不成功;
pip install py2exe依然沒有裝成功;
2.關於PyInstaller和py2exe兩者的比較,說是,用py2exe會在生成exe的文件夾里同時生產一堆文件,PyInstaller只會生成一個;
另一方面:說是,py2exe對32位或者64位的相互支持不好,32位上生產的到64位上有可能不能用;我用的PyInsataller,在32位上生產,
64位上也可用;
3.PyInstaller區分32位和64位,安裝和python位制一致的即可;
4.關於是否需要將用到的模塊拷貝到 .py的目錄下
網上有人說需要放置在一起,我嘗試了沒有放置在一起,依然可以
11.字符串的處理
(1)截取部分
data = data[:-4]
#將最后4個干掉
data = data[2:4]
#獲取字符串中的第3和第4個
(2)替換
data = data.replace('需要被替換的內容','替換前者的內容')
[技巧]:
1.檢測模塊是否安裝成功:模塊安裝完成后,可在cmd下輸入python,再import 模塊名,看看是否安裝成功;
2.檢測API返回值類型:print(type())
3.CRC模塊算出來的值可以通過工具(CRC Calculator 圖標是算盤)進行效驗下
代碼:
聲明:沒有做封裝,也沒有注意寫法和命令等,純粹為了實現功能和學習用;
# -*- coding:UTF-8 -*-
from serial import *
from binascii import *
from crcmod import *
import time
# def crc16Cal(x):
# a = 0x0000
# b = 0x1021
# for byte in x:
# a ^= ord(byte)
# a <<= 8
# for i in range(8):
# a <<= 1
# last = a & 0x8000
# if last == 1:
# a ^= b
# s = hex(a)
# return s[4:6]+s[2:4]
readFun = '68020000'
crc16_cmodem = crcmod.mkCrcFun(0x11021,rev=False,initCrc=0x0000,xorOut=0x0000)
readCrcOUT = hex(crc16_cmodem(unhexlify(readFun)))
readCrcOUT = readCrcOUT[2:4]+readCrcOUT[4:6]
print(readCrcOUT)
readFun += readCrcOUT
print(readFun)
readFun = unhexlify(readFun)
ser = Serial("COM19",115200)
print(readFun)
ser.write(readFun)
data = ser.read(58)
data =hexlify(data)
print(data)
data = data.replace('68023400','68033400')
print(data)
data = data[:-12]
print(data)
data += '03000000'
print(data)
readCrcOUT = hex(crc16_cmodem(unhexlify(data)))
readCrcOUT = readCrcOUT[2:4]+readCrcOUT[4:6]
print(readCrcOUT)
data += readCrcOUT
print(data)
data = unhexlify(data)
ser.write(data)
#sleep
time.sleep(2)
#reset
reset = '68010000'
readCrcOUT = hex(crc16_cmodem(unhexlify(reset)))
readCrcOUT = readCrcOUT[2:4]+readCrcOUT[4:6]
reset += readCrcOUT
reset = unhexlify(reset)
ser.write(reset)
ser.close()