1

我想知道 Python 编程的一个非常基本的东西,因为我现在是一个非常基本的程序员):如何将结果(列表、字符串或其他)保存到 Python 中的文件中?我一直在寻找很多,但我找不到任何好的答案。我在考虑“.write ()”方法,但是(例如)它似乎不适用于字符串,但我也不知道它应该做什么。所以,我的情况是我有二进制文件,我想编辑它,因此我发现很容易将它们转换为字符串,修改它们,现在我想将它们保存 i)回二进制文件(jpegs 图像) ii) 在我想要的文件夹中。我该怎么做?请我需要一些帮助。

更新

这是我要运行的脚本:

import os, sys

newpath= r'C:/Users/Umberto/Desktop/temporary'
if not os.path.exists (newpath):
    os.makedirs (newpath)

data= open ('C:/Users/Umberto/Desktop/Prove_Script/Varie/_BR_Browse.001_2065642654_1.BINARY', 'rb+')
edit_data= str (data.read () )
out_dir= os.path.join (newpath, 'feed', 'address')

data.close ()


# do my edits in a secon time...

edit_data.write (newpath)

edit_data.close ()

我得到的错误是:

AttributeError: 'str' object has no attribute 'write'

更新_2

我尝试使用pickle模块序列化我的二进制文件,修改它并在最后保存它,但仍然没有让它工作......这是我迄今为止一直在尝试的:

import cPickle as pickle
binary= open ('C:\Users\Umberto\Desktop\Prove_Script\Varie\_BR_Browse.001_2065642654_1.BINARY', 'rb')
out= open ('C:\Users\Umberto\Desktop\Prove_Script\Varie\preview.txt', 'wb')
pickle.dump (binary, out, 1)

TypeError                                 Traceback (most recent call last)
<ipython-input-6-981b17a6ad99> in <module>()
----> 1 pprint.pprint (pickle.dump (binary, out, 1))

C:\Python27\ArcGIS10.1\lib\copy_reg.pyc in _reduce_ex(self, proto)
     68     else:
     69         if base is self.__class__:
---> 70             raise TypeError, "can't pickle %s objects" % base.__name__
     71         state = base(self)
     72     args = (self.__class__, base, state)

TypeError: can't pickle file objects

我没有得到的另一件事是,如果我应该创建一个指向的文件(在我的情况下,我必须创建“out”,否则我不会为 pickle 方法提供正确的参数)或者没有必要. 希望我越来越接近解决方案。

PS:我也尝试了pickle.dumps(),但没有取得更好的结果......

4

2 回答 2

9

如果您正在打开一个二进制文件并保存另一个二进制文件,您可以执行以下操作:

with open('file.jpg', 'rb') as jpgFile:
    contents = jpgFile.read()

contents = (some operations here)

with open('file2.jpg', 'wb') as jpgFile:
    jpgFile.write(contents)

一些评论:

  • 'rb' 和 'wb' 分别表示以二进制模式读取和写入。有关在此处处理二进制文件时为什么推荐使用“b”的更多信息。
  • Python 的with 语句负责在退出块时关闭文件。

如果您需要保存列表、字符串或其他对象,并在以后检索它们,请使用其他人指出的pickle 。

于 2013-03-04T15:44:35.380 回答
0

您可以使用名为“pickle”的标准 python 模块。

你可以在这里阅读:pickle 文档

读写任何数据结构都会很容易

pickle.dump(obj, file_handler) # for serialize object to file
pickle.load(file)              # for deserialize from file

或者您可以序列化为字符串:pickle.dumps(..) 并从中加载:pickle.loads(...)

于 2013-03-04T15:45:39.313 回答