python打开xls_python读取XLS文件或CSV文件

这篇博客介绍了如何使用Python的xlrd库读取XLS文件,并展示了通过检查第一张表来处理数据的方法。同时,也讲解了当文件为CSV格式时,如何借助StringIO和csv库进行读取。内容包括读取文件、获取行数、存储数据到列表以及处理可能出现的错误。

file_obj = request.FILES.get('uploadcsv','')

#如果传入的是XLS文件

import xlrd

#1.读取XLS内容

bk = xlrd.open_workbook(file_contents = file_obj.read())

#2.或者是告诉它文件路径,如下

#bk = xlrd.open_workbook(path/to/xls)

try:#看是不是XLS的第一张表

sh = bk.sheet_by_index(0)

except:

return render_to_response('admins/message.html',{'message':'没有读取到您的第一张表!'},context_instance=template.RequestContext(request))

#计算文件的总行数

nrows = sh.nrows

reader = []

#再循环将每一行的数据写进一个LIST中备用

for i in range(nrows):

row_data = sh.row_values(i)

reader.append(row_data)

#如果传入的是CSV文件

import StringIO,csv

data = StringIO.StringIO(file_obj.read())

try:

reader = csv.reader(data)

except Exception,e:

return render_to_response('admins/message.html',{'message':'CSV文件没有正常读取,请重新检查后上传!2'},context_instance=template.RequestContext(request))

最后再FOR循环reader这个列表,读出每个数据即可

分享到:

18e900b8666ce6f233d25ec02f95ee59.png

72dd548719f0ace4d5f9bca64e1d7715.png

2010-02-02 10:15

浏览 6052

评论

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值