首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何将csv.Sniffer用于两种不同的CSV-类型?

如何将csv.Sniffer用于两种不同的CSV-类型?
EN

Stack Overflow用户
提问于 2013-02-26 16:14:57
回答 1查看 13.6K关注 0票数 8

我想阅读两种不同类型的CSV-文件:

  • ','作为分隔符的
  • ';'作为分隔符的

我试图通过以下操作来检查我使用的是哪个分隔符:

代码语言:javascript
复制
dialect = csv.Sniffer().sniff(csvfile, [',', ';'])  
data = csv.reader(csvfile, dialect)

但是我得到了TypeError : expected string or buffer

如果我这样做,它可以工作,但我不知道什么时候使用什么分隔符。

代码语言:javascript
复制
data = csv.reader(csvfile, delimiter = ",")  
data = csv.reader(csvfile, delimiter = ";")

有人能帮帮我吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-02-26 16:19:54

Sniffer期望的是样本串,而不是文件。你所需要做的就是:

代码语言:javascript
复制
dialect = csv.Sniffer().sniff(csvfile.readline(), [',',';'])
csvfile.seek(0)  
data = csv.reader(csvfile, dialect)

查找很重要,因为您正在使用readline命令移动文件中的当前位置,并且需要将其重新设置为文件的开头。否则你会丢失数据。

票数 28
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15093952

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档