POST 上传的 excel(xls)文件,如何直接读进 pandas,避免写入到磁盘?

2016-09-20 14:54:21 +08:00
 codenamea
csv 文件我可以这样写代码,已测试没有问题。但是 execl 文件用 TextIOWrapper 好像不行。

file = request.files['files']
csvfile = io.TextIOWrapper(file.stream, encoding='gbk')
reader = csv.reader(csvfile)

然而我 pandas 读取 excel 的时候:

file = request.files['files']
execlfile = io.TextIOWrapper(file.stream)
data_from_excel = pd.read_excel(execlfile, header=0, encoding='gbk')

报错:
builtins.UnicodeDecodeError
UnicodeDecodeError: 'gbk' codec can't decode byte 0xba in position 22: illegal multibyte sequence
编码这里我换了 gbk,utf-8 都不行


但是当我尝试着本地读取的话,简单一句就能成功读取了。。
temp=pd.read_excel("1.xls")
所以到底是哪里出了问题?
2823 次点击
所在节点    Python
3 条回复
glasslion
2016-09-20 22:40:04 +08:00
`execlfile = io.TextIOWrapper(file.stream) ` 这里需要指明 encoding 吧
codenamea
2016-09-23 11:20:24 +08:00
@glasslion 我后面说了编码这里我换了 gbk,utf-8 都不行
Arthur2e5
2016-09-27 11:24:29 +08:00
当你尝试用 TextIOWrapper 钦定这东西是有效的某种编码的纯文本的时候就已经在犯了用记事本打开文件的错误了。你要在已有的 stream (已经是 file-like 了吧?)上面再构造 file-like 的话可以看看 io.BufferedReader 之类的东西,反正不要搞 text 。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/307536

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX