我有一些读取URL和写入磁盘的代码。在这里-
url = 'http://www.cs.purdue.edu/homes/ninghui/courses/Spring06/lectures/lecture05.pdf'
ret = requests.get(url)
print ret.headers
print ret.headers['content-encoding']
print ret.headers['content-type']
pathToWrite = 'tmp/test.pdf'
try:
fd = os.open(pathToWrite, os.O_RDWR | os.O_CREAT)
try:
os.write(fd, ret.text)
except Exception as e:
print 'cannot write to file ' + pathToWrite
raise
try:
os.close(fd)
except:
print 'cannot close file ' + pathToWrite
raise
except:
print 'file cannot be opened ' + pathToWrite
raise
通过上面的代码,我可以得到一个pdf文件并将其写入磁盘,我得到以下错误-
UnicodeEncodeError: 'charmap' codec can't encode characters in position 12-13: character maps to <undefined>
当我使用下面的API时,也会出现同样的错误-
f = open(pathTowWrite, 'wb')
f.write(ret.text)
我觉得我错过了一些明显的东西。这似乎太简单了,不会出错。你知道吗
你想写
ret.content
而不是ret.text
。ret.text
尝试将PDF转换为Unicode,这对于像PDF这样的二进制格式可能是不可能的。你知道吗另外,您可以只使用内置的open函数。这里不需要低水平的
os.open
。你知道吗相关问题 更多 >
编程相关推荐