我有一個Python腳本,處理數據文件:寫空字節的文件,而不是正確的字符串
out = open('result/process/'+name+'.res','w')
out.write("source,rssi,lqi,packetId,run,counter\n")
f = open('result/resultat0.res','r')
for ligne in [x for x in f if x != '']:
chaine = ligne.rstrip('\n')
tmp = chaine.split(',')
if (len(tmp) == 6):
out.write(','.join(tmp)+"\n")
f.close()
的完整源代碼here
我使用這個腳本在多臺計算機和行爲不一樣。 在第一臺計算機上,使用python 2.6.6,結果就是我所期望的。 然而,在其他(python 2.6.6,3.3.2,2.7.5)文件對象的寫入方法放置空字節,而不是在大多數處理期間我想要的值。我得到這個結果:
$ hexdump -C result/process/1.res
00000000 73 6f 75 72 63 65 2c 72 73 73 69 2c 6c 71 69 2c |source,rssi,lqi,|
00000010 70 61 63 6b 65 74 49 64 2c 72 75 6e 2c 63 6f 75 |packetId,run,cou|
00000020 6e 74 65 72 0a 00 00 00 00 00 00 00 00 00 00 00 |nter............|
00000030 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
*
0003a130 00 00 00 00 00 00 00 00 00 00 31 33 2c 36 35 2c |..........13,65,|
0003a140 31 34 2c 38 2c 39 38 2c 31 33 31 34 32 0a 31 32 |14,8,98,13142.12|
0003a150 2c 34 37 2c 31 37 2c 38 2c 39 38 2c 31 33 31 34 |,47,17,8,98,1314|
0003a160 33 0a 33 2c 34 35 2c 31 38 2c 38 2c 39 38 2c 31 |3.3,45,18,8,98,1|
0003a170 33 31 34 34 0a 31 31 2c 38 2c 32 33 2c 38 2c 39 |3144.11,8,23,8,9|
0003a180 38 2c 31 33 31 34 35 0a 39 2c 32 30 2c 32 32 2c |8,13145.9,20,22,|
你有什麼想法如何解決這個問題嗎?
我查看了鏈接中的完整代碼。你是Python和麪向對象編程的新手?問題在於你使用全局變量並在各個地方打開文件,將文件句柄存儲在字典中:這是非常難以理解的。你的代碼拼命需要重構。 – MattH
一些一般的評論。你有沒有試過調試器?在列表理解中添加一個打印語句以驗證輸出是否如預期的那樣。不要使用'rstrip',嘗試使用'strip()'去除所有行尾字符,包括尾隨空格。 –
我嘗試使用print-statement,輸出是正確的行,而不是空字節。 – user2523255