如何解决从中获取代表文件的所有字节
我正在用python创建服务器-客户端代码,并且试图通过读取文件的字节并将其发送来将图像文件从服务器发送到客户端。 由于某些原因,已读取的字节不代表可以看到的适当文件-当我将读取的字节保存为图像时,它们不会提供我扫描主题的图像。
elif command == COMMANDS[1]:
print(f'Reading the bytes of {params[0]}')
f = open(params[0],'rb')
data = f.read()
if os.path.exists(r'C:\Users\orlav\Desktop\networking_book_stuff\tech_server\screen2.jpg'):
os.remove(r'C:\Users\orlav\Desktop\networking_book_stuff\tech_server\screen2.jpg')
f2 = open(r'C:\Users\orlav\Desktop\networking_book_stuff\tech_server\screen2.jpg','wb+')
f2.write(data)
由于某种原因f2不包含f包含的内容
解决方法
打开文件以供在Python中进行读写操作始终需要放在with
块中,以免造成麻烦。
正确阅读:
with open(file_name,'rb') as f:
data = f.read()
正确的写作:
with open(file_name,'wb') as f:
f.write(data)
with
块强制每当块结束(包括由于异常而导致块结束的情况)时正确关闭和刷新文件。
如果仅使用open(...)
而不使用with
打开文件,则如果完全正确地刷新程序,则在程序完成之前它不会关闭/清除。如果打开文件进行写入而未关闭,则文件可能只是部分写入。如果已打开文件以供读取而未关闭,则删除此文件也可能会导致问题。如果未多次关闭用于缓冲区的内存,则用于读取和写入的操作都不会释放,从而导致在重复执行多次打开/读取操作时发生巨大的内存泄漏。
始终使用with
块打开文件进行读取和写入,以在块完成后正确关闭文件。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。