テキストファイルからデータを読み取り、MySqlデータベースに保存しています。テキストファイルのデータ形式はテキストファイルデータをMySqlに保存し、タイムスタンプを引用符で囲み ""と一部のデータ値がありません
"sd","modu","datfil","244","de3000.Std.27","CPU:KC.EBM1_16.02.18.cd","13","ffm"
"TIMESTAMP","RNO","tem","t_vel","tem_acc","velc","sd","sd_ds_as"
"","","mp","mp","mp","mp","mp","mp"
"2009-02-25 14:28:36.76",missing RNO,8.277527,0.68,0.15,0.42,762.0303,4.6801
"2009-02-25 14:28:36.8",missing RNO,8.24408,0.7,0.03,0.3,761.878,4.682412
"2009-02-25 14:29:36.88",2,8.277527,0.55,0.09,0.31,762.0018,4.680709
"2009-02-25 14:30:36.92",3,8.277527,0.47,0.2,0.31,761.8914,4.684526
"2009-02-25 14:48:36.96",4,8.277527,0.46,0.14,0.28,761.9133,4.692356
"2009-02-25 14:58:37",5,8.210632,0.42,0.09,0.35,761.9025,4.696963
"2009-02-25 14:58:37.08",6,8.277527,0.51,0.19,0.27,761.8416,4.69718
"2009-02-25 14:58:37.12",7,8.277527,0.36,0.23,0.33,761.7534,4.701172
"2009-02-25 14:58:37.16",8,8.24408,0.44,0.08,0.5,761.8087,4.700504
ある問題は、タイムスタンプが「」で囲まれ、また、いくつかのデータ値がmilisecondが含まれていることです。この問題に対処するために、私は次のコード
with open(filepath) as f:
lines = f.readlines()
max_lines = len(lines)
for k, line in enumerate(lines):
if k >= (int(skip_header_line) + int(index_line_number)): # skipping headerlines
data_tmp = line.split(',')
strDate = data_tmp[0].replace("\"", "") # 2016-02-25 14:48:36.76
strDate = strDate.split('.')[0] # 2016-02-25 14:48:36
timestamp = datetime.datetime.strptime(strDate, '%Y-%m-%d %H:%M:%S') # 2016-02-25 14:48:36
ts = calendar.timegm(timestamp.timetuple()) # 1456411716
data_buffer = [ts] + data_tmp[1:]
for val in data_buffer:
if val == " ":
val = None
data_buffer.append(val)
else:
continue
print data_buffer
cursor.execute(add_data, data_buffer)
cnx.commit()
with open(marker_file, "w") as f:
f.write(" ".join([ str(item[0]), str(data_tmp[0]), str(max_lines), str(k-int(skip_header_line)+1) ]))
cursor.close()
cnx.close()
作る誰かがこのような状況に対処する方法任意のアイデアを持っていた場合、私は次のようなエラー
[1456411716, ' ', '8.277527', '0.68', '0.15', '0.42', '762.0303', '4.6801\n']
mysql.connector.errors.DatabaseError: 1265 (01000): Data
truncated for column 'RNO' at row 1
を得ました。私は本当に感謝します。
何ラインはあなたにエラーを与えますか? –
@JuanCarlosOropeza私はこの行に問題があります。 data_buffer.append(float(val))。それ以外の行は – Rio
です。問題は何か分かりませんが、テキストとして保存し、dbに別の列を作成してテキスト値を使用して更新することができます。 –