1

使用下面的代码,我得到了文件的正确信息——有点。这是代码:

filename = raw_input('What would you like to name the file? ')

import csv

data = [frames]
out = csv.writer(open(filename,"w"), delimiter=' ',quoting=csv.QUOTE_MINIMAL)
out.writerows(data)

这会在文本文件中生成如下所示的内容:

"[255   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
   0   0]" "[  0 171 171 171 171 171 171 171 171 171 171 171 171 171 171 171 171 171
 171 171]" 

我希望信息看起来像这样:

255 255 255 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 []0 255 255 255 255 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

2 个括号代表一个字符,表示新的信息行。这是我的文本编辑器上的一个小矩形,我不确定这个字符是什么。

那么,我如何摆脱引号和括号并使用其他字符呢?

编辑:

我尝试使用下面的代码并收到以下错误:

Traceback (most recent call last):   
  File "(stdin)", line 1, in (module)   
  File "backandforth3.py", line 154, in (module)
    out.write(' '.join(frame)) 
Type Error: sequence item 0: expect string, numpy.int32 found
4

2 回答 2

4

我假设您使用记事本作为文本编辑器?Unix 样式的换行符 ( \n) 在记事本中显示为方框,因为它仅支持 Windows 换行符 ( \r\n)。也就是说,这应该提供您期望的输出:

filename = raw_input('What would you like to name the file? ')

with open(filename, 'wb') as out:
    for frame in frames:
        out.write(' '.join(str(num) for num in frame))
        out.write('\r\n')

没有理由包含frames在另一个列表中;假设变量是数字列表的列表,正如预期的输出所示,这应该可以正常工作。

此外,如果您绝对必须拥有您在输出中描述的“框”,请替换'\r\n''\n'.

于 2012-07-28T02:55:11.660 回答
0

如果frames是一个 numpy 数组,则可以使用numpy.savetxt()函数:

numpy.savetxt(filename, frames)

要修复您的csv代码以二进制模式打开文件wb以避免损坏行尾,并且不要包装frames在另一个列表中,它似乎已经是一个二维数组:

import csv

with open(filename,"wb") as f:
    writer = csv.writer(f, delimiter=' ', quoting=csv.QUOTE_MINIMAL)
    writer.writerows(frames)
于 2012-07-28T18:45:51.043 回答