import os
import struct
import pandas as pd
def readTdxLdayFile(fname="C:\\TdxW_HuaTai\\vipdoc\\sh\\lday\\sh601628.day"):
dataSet=[]
with open(fname,'rb') as fl:
buffer=fl.read() #读取数据到缓存
size=len(buffer)
rowSize=32 #通信达day数据,每32个字节一组数据
code=os.path.basename(fname).replace('.day','')
for i in range(0,size,rowSize): #步长为32遍历buffer
row=list( struct.unpack('IIIIIfII',buffer[i:i+rowSize]) )
row[1]=row[1]/100
row[2]=row[2]/100
row[3]=row[3]/100
row[4]=row[4]/100
row.pop() #移除最后无意义字段
row.insert(0,code)
dataSet.append(row)
data=pd.DataFrame(data=dataSet,columns=['code','tradeDate','open','high','low','close','amount','vol'])
print(data)
readTdxLdayFile()
Python将通信达.day文件读取为DataFrame
最新推荐文章于 2025-01-21 08:55:36 发布
本文介绍了一个Python函数,该函数用于解析特定路径下的TdxLdayFile文件,并将其内容转换为易于处理的DataFrame格式。通过对原始数据的逐字节解析,函数能够正确地提取股票代码、交易日期、开盘价、最高价、最低价、收盘价、成交量等关键信息。

4762

被折叠的 条评论
为什么被折叠?



