根据XLRD模块的文档,
row_values(rowx, start_colx=0, end_colx=None)
“返回给定行中单元格值的切片。”
并给出以下python代码:
import xlrd
wb=xlrd.open_workbook("xl1.xlsx")
sh = wb.sheet_by_index(0)
for rownum in range(sh.nrows):
print sh.row_values(rownum)
输出结果为:
[12.0, u'test.0']
[34.0, u'te.st']
[u'test123', u'12.test']
并且exel文件包含以下数据:
12.0,test.0,34.0,te.st,test123,12.test
那么,根据输出,我可以获得哪种类型的数据结构? 它不是一个元组,(因为在打印元组类型时,没有u'作为字符串的前缀),u'的意思是什么? 而且它就像我们在数据结构中有两种类型的数据 - int和“non int”。 这是真的吗?我在文档中找不到任何相关信息。 谢谢!
答案 0 :(得分:2)
row_values
返回具有适当数据类型的单元格值列表。列表中每个项目的数据类型取决于源excel文件中的单元格类型。
可能只有string
,float
和int
数据类型的项目,请参阅此mapping table(查找Cell
的文档)以获取更多信息
u
只是意味着这是一个unicode字符串。 Documentation很好地解释了它。
希望有所帮助。
答案 1 :(得分:0)
首先要做的事情!
我不知道你使用的是哪个版本的xlrd但是根据最新版本(在写这个答案时xlrd 0.9.4):
row_values()
将以列表的形式返回行中的值。这可以通过输入以下内容来验证:
>>> type(sh.row_values(2))
<type 'list'>
接下来,为了获取包含数据类型的行的值,您可以键入以下内容:
>>> sh.row(2)
这会给你带来这样的东西:
[number:12.0, text:u'test.0']
表示列表中的第一项是数字,第二项是字符串或也称为文本。
最后,字符串前面的u
表示它是Unicode编码。请记住,xlrd模块将尝试将excel表中的每个数据呈现为unicode编码,因此您看到u