热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Python对Excel文件的读取方法及模块安装

本文介绍了Python对Excel文件的读取方法,包括模块的安装和使用。通过安装xlrd、xlwt、xlutils、pyExcelerator等模块,可以实现对Excel文件的读取和处理。具体的读取方法包括打开excel文件、抓取所有sheet的名称、定位到指定的表单等。本文提供了两种定位表单的方式,并给出了相应的代码示例。

今天研究了一下Python对Excel文件的读取,在此分享一下。

1.模块安装

想通过python对Excel文件进行处理,需要安装以下几个模块:

  • pip install xlrd
  • pip install xlwt
  • pip install xlutils
  • pip install pyExcelerator

2.Excel文件读取方法


import xlrd#1.打开excel文件
workbook = xlrd.open_workbook('test.xlsx')
#2.抓取所有sheet的名称,Python会以列表的方式保存
worksheets = workbook.sheet_names()
print(worksheets) # ['Sheet1', 'Sheet2', 'Sheet3']#3.定位到Sheet1表单,worksheet1是一个表单对象#方式一:
worksheet1 = workbook.sheet_by_name('Sheet1')print(worksheet1) # #方式二:
worksheet2 = workbook.sheets()[0]print(worksheet2) ## 4.遍历所有的表单对象
for worksheet_name in worksheets:worksheet = workbook.sheet_by_name(worksheet_name)print(worksheet)# 5.遍历所有的行
num_rows = worksheet1.nrows
for curr_row in range(num_rows):row = worksheet1.row_values(curr_row)print('row%s is: %s'%(curr_row,row))# 6.遍历所有的列
num_cols = worksheet1.ncols
for curr_clo in range(num_cols):clo = worksheet1.col_values(curr_clo)print('clo %s is: %s' %(curr_clo,clo))# 7.遍历所有的单元格(方法一从行开始)
for rown in range(num_rows):for coln in range(num_cols):cell = worksheet1.cell_value(rown,coln)print(cell)# 8.遍历所有的单元格(方法二从列开始)
for coln in range(num_cols):for rown in range(num_rows):cell = worksheet1.cell_value(rown,coln)print(cell)# 9.遍历所有单元格(方法三)
for rown in range(num_rows):for coln in range(num_cols):cell = worksheet1.cell(rown,coln).valueprint(cell)# 10.遍历所有单元格(方法四)
for rown in range(num_rows):for coln in range(num_cols):cell = worksheet1.row(rown)[coln].valueprint(cell)# 11.遍历所有单元格(方法五)
for coln in range(num_cols):for rown in range(num_rows):cell = worksheet1.col(coln)[rown].valueprint(cell)

3.案例一

读取Excel文件表单某一列的数据并保存至txt文件

'''
需求:
读取Excel文件 test.xlsx表单Sheet1里第二列数据,并写入到以Sheet1名字命名的.txt文件中
'''

import xlrd#1.打开excel文件
workbook = xlrd.open_workbook('test.xlsx')#2.抓取所有sheet的名称,Python会以列表的方式保存
worksheets = workbook.sheet_names()
print(worksheets)#3.定位到Sheet1
worksheet = workbook.sheet_by_name('Sheet1')
print(worksheet)#4.将第二列数据读取出来col = worksheet.col_values(1)
print(col)#5.将第二列的内容写入到Sheet1.txt(以表单名字命名的txt文件)文本文件中length = len(col)
print(length)with open(worksheets[0]+".txt",'w') as file_obj:for num in range(length):file_obj.write(col[num])file_obj.write('\n')num+=1

4.案例二

读取Excel文件所有表单所有数据并保存至以表单名字命名的txt文件:

'''
需求:
读取Excel文件 test.xlsx所有表单里的所有数据,并写入到以表单名字命名的.txt文件中
'''

import xlrd#1.打开excel文件
workbook = xlrd.open_workbook('test.xlsx')#2.抓取所有sheet的名称,Python会以列表的方式保存
worksheets = workbook.sheet_names()
print(worksheets)#3.遍历所有表单
for worksheet_name in worksheets:worksheet = workbook.sheet_by_name(worksheet_name)print(worksheet)
#4.求表单sheet行数和列数num_rows = worksheet.nrowsnum_cols = worksheet.ncols
#5.将表单sheet里面的数据写入到以sheet名字命名的.txt文件中with open(worksheet_name+".txt",'w') as file_obj:for rown in range(num_rows):for coln in range(num_cols):cell = worksheet.cell_value(rown,coln)file_obj.write(str(cell))file_obj.write('\t')file_obj.write('\n')


推荐阅读
author-avatar
岁月掌心_447
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有