Python中excel读写模块简介---xlrd、xlwt模块_xlrd3与xlrd-程序员宅基地

模块功能

Python语言中,读写Excel的扩展工具--模块xlrd、xlwt:

xlrd意为:xls文件read库,只能读,可以实现指定表单、指定单元格的读取;

xlwt意为:xls文件write库,只能写,可以实现指定表单、指定单元格的写入;

发展历史

python2.X 版本下,使用xlrd、xlwt扩展包。
python3.X 版本下,需要更新到xlrd3、xlwt3扩展包。
用法介绍
1、xlrd
1)导入excel读取模块
import xlrd
2)打开Excel文件读取数据
data = xlrd.open_workbook('excelFile.xls')
注:括号中也可以是文件路径如"E:\\
excelFile.xls"
3)获取excel文件中的信息
(1)获取一个工作表即sheet页
table = data.sheets()[0] #通过索引顺序获取sheet页
table = data.sheet_by_index(0) #通过索引顺序获取sheet页
table = data.sheet_by_name(u'Sheet1')#通过名称获取sheet页
(2)获取某个sheet页中整行(row)和整列(column)的值(数组)
datalist=table.row_values(i)
datalist=table.col_values(i)
(3)获取某个sheet页中存在数据的行数和列数
nrows = table.nrows
ncols = table.ncols
(4)循环每一行数据列表
for i in range(nrows ):
    print table.row_values(i)
(5)定位单元格并读取单元格内容
table.cell(rowx,colx)
cell_A1 = table.cell(0,0).value
cell_C4 = table.cell(3,2).value
(6)使用行列索引
cell_A1 = table.row(0)[0].value
cell_A2 = table.col(1)[0].value
(7)简单的写入
row = 0
col = 0
# 类型 0 empty,1 string, 2 number, 3 date, 4 boolean, 5 error
ctype = 1value = '单元格的值'
xf = 0# 扩展的格式化
table.put_cell(row, col, ctype, value, xf)
table.cell(0,0) #单元格的值'
table.cell(0,0).value #单元格的值'

2、xlwt
(1)导入模块
import xlwt
(2)创建workbook(其实就是excel,后来保存一下就行)
workbook = xlwt.Workbook(encoding = 'ascii')
(3)创建表
worksheet = workbook.add_sheet('My Worksheet')
(4)往单元格内写入内容
worksheet.write(0, 0, label = 'Row 0, Column 0 Value')
(5)保存
workbook.save('Excel_Workbook.xls')
案例解读
1、xlrd

  
  
   
#-*-coding:utf-8-*-
import xlrd
def open_excel(file='file.xls'):
    try:
        data=xlrd.open_workbook(file)
        return data
    except Exception,e:
        print str(e)
         
#根据索引获取Excel表格中的数据参数:file:Excel文件路径colname_index:表头列名所在行的所以,by_index:表的索引
def excel_table_byindex(file='file.xls',colname_index=0,by_index=0):
    data=open_excel(file)
    table=data.sheets()[by_index]
    nrows=table.nrows#行数
    ncols=table.ncols#列数
    colnames=table.row_values(colname_index)#某一行数据
    res_list=[]
    for rownum in range(1,nrows):
        row=table.row_values(rownum)
        if row:
            app={}
            for in range(len(colnames)):
                app[colnames[i]]=row[i]
                res_list.append(app)
    return res_list
  
#根据名称获取Excel表格中的数据参数:file:Excel文件路径colname_index:表头列名所在行的所以,by_name:Sheet1名称
def excel_table_byname(file='file.xls',colname_index=0,by_name=u'Sheet1'):
    data=open_excel(file)
    table=data.sheet_by_name(by_name)
    nrows=table.nrows#行数
    colnames=table.row_values(colname_index)#某一行数据
    res_list=[]
    for rownum in range(1,nrows):
        row=table.row_values(rownum)
        if row:
            app={}
            for in range(len(colnames)):
                app[colnames[i]]=row[i]
                res_list.append(app)
    return res_list
  
def main():
    tables=excel_table_byindex()
    for row in tables:
        print row
      
    tables=excel_table_byname()
    for row in tables:
        print row
  
if __name__=="__main__":
    main()

2、xlwt
  
  
   
importxlwt
fromdatetimeimportdatetime
 
font0=xlwt.Font()
font0.name='TimesNewRoman'
font0.colour_index=2
font0.bold=True
 
style0=xlwt.XFStyle()
style0.font=font0
 
style1=xlwt.XFStyle()
style1.num_format_str='D-MMM-YY'
 
wb=xlwt.Workbook()
ws=wb.add_sheet('ATestSheet')
 
ws.write(0,0,'Test',style0)
ws.write(1,0,datetime.now(),style1)
ws.write(2,0,1)
ws.write(2,1,1)
ws.write(2,2,xlwt.Formula("A3+B3"))
 
wb.save('example.xls')

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/xianjie0318/article/details/76522509

智能推荐

idea控制台中文乱码解决办法_idea 2023.2\bin" -dfile.encoding=utf-8-程序员宅基地

idea控制台中文乱码解决办法一、file --->Settings —>Editor —>File Encodings二、Help —> Edit Custom VM Options三、在Tomcat上添加四、Tomcat安装目录下的conf配置logging.properties的文件,如下图位置改为DBK五、在Idea的安装目录bin:打开如下两个,在其中添加六、在pom.xml文件中添加到这里就结束了,如果有遗漏的地方,可以告诉我,我添上。希望可以给朋友们带来帮助。一、f_idea 2023.2\bin" -dfile.encoding=utf-8

魔法大锅炉_约定价值和销售价值区别-程序员宅基地

Eric S. Raymond五部曲之The Magic Cauldron魔法大锅炉—— 前言、目录Eric Raymond (1999年六月)[AKA]rover HansB iasc等翻译 --------------------------------------------------------------------------------   本文分析了正在不断发展的开放_约定价值和销售价值区别

k8s学习笔记——iptables基础_k8siptables-程序员宅基地

表顺序:raw - mangle - nat - filterFILTER:INPUT链 处理来自外部的数据 OUTPUT链 处理向外发送的数据 FORWARD链 将数据转发到本机的其他网卡设备上NAT: PREROUTING链 处理刚到达本机并在路由转发前的数据包,常用于DNAT POSTROUTING链 处理即将离开本机的数据包,常用于SNAT OUTPUT链 处理本机产生的数据包MANGLE: 用于指定如何处理数据包。能改变TCP头中的QoS..._k8siptables

安装新版的winetricks_Wine安装最新版QQ(8.9.2)的简单教程-程序员宅基地

本教程为本人在看了许多前辈有关WineQQ的文章后整理出来的,只保留最必须的步骤,略去多余步骤。到目前为止,关于WineQQ的安装的文章我已经写了3篇了,分别是ukylin论坛中的WineQQ7.8、WineQQ8.9.1和这次的WineQQ8.9.2。按理来说同一个类型的文章没有必要写这么多篇,但是本着分享和探索的原则,我还是写了,并且未来还会写很多。每一篇文章我都基于当时的环境进行了细致的测试..._wine8 qq

Linux FTP服务器搭建(Docker)_3. 创建 ftp 用户登入时的主目录的父目录_闲猫的博客-程序员宅基地

目录mkdir -p /opt/ftpData​​​​​​​用户创建一个 FTP 用户组,用于存放 FTP 用户。# groupadd ftpgroup创建 FTP 用户登入时的主目录的父目录# cd /home/# pwd/home# mkdir ftpusers# cd ftpusers/# pwd/home/ftpusers创建一个 FTP 用户创建一个 FTP 用户,指定登入时的主目录并加入 ftpgroup 组:# useradd -d _3. 创建 ftp 用户登入时的主目录的父目录

Qt控件--QComboBox_duplicatesenabled_Simple_core的博客-程序员宅基地

Qt控件--QComboBoxQComboBox属性editable : boolcurrentText : QStringcurrentIndexmaxVisibleItems : intmaxCount : intinsertPolicy : InsertPolicysizeAdjustPolicy : SizeAdjustPolicyminimumContentsLength : inticonSize : QSizeduplicatesEnabled : boolframe : boolmodelC_duplicatesenabled

随便推点

L2tp 虚拟专有网络 (预共享密钥)-程序员宅基地

本环境为AWS EC2 instance Amazon Linux :1、安装所需软件yuminstallmakegccgmp-develbisonflexlsofwgetlibpcap-develppppolicycoreutils2、下载、安装、配置openswan[root@redis01-jp~]#wget--no-check-certi..._l2tp共享密钥怎么获取

X509Certificate2 找不到文件 找不到证书-程序员宅基地

System.Security.Cryptography.CryptographicException: 系统找不到指定的文件X509Certificate2 tempSignCert = new X509Certificate2(证书, "密码");本地调试成功,发布到远程云服务器失败,提示找不到指定文件。File.Exists(Server.MapPath("证书"))判断文件

设计模式---装饰模式-程序员宅基地

http://blog.csdn.net/hailong0715/article/details/51751208装饰器模式(DECRATOR):为了实现动态的给对象添加职能,即从外部给对象添加相关职能。可以这样理解,比如说一个Person类,该类的操作有能吃、能睡、能跑、但假如随着人类的进化,某一天Person能飞了,能在水里游了等等,按照一般的写法是修改Person这个类,

CCS v5.0打开项目文件时出现错误:“The project description file (.project) for 'test_ad' is missing. This file c”-程序员宅基地

我用CCS v5.0打开已经编译工程文件时,显示错误“The project description file (.project) for 'test_ad' is missing. This file contains important information about the project. The project will not function properly until

Web前端面试题——浅谈盒子模型-程序员宅基地

CSS盒子模型引用官方的话,所有html元素可以看作盒子,CSS盒模型本质是一个盒子,封装周围的HTML元素,包括外边距,边框,内边距和内容W3C盒子模型(标准盒子模型)一般来讲我们在CSS中定义的width和height都是设置content的宽高,而盒子的总宽高 = content宽高 + 2 * margin + 2 * padding + 2 * borderIE盒子模型(怪异盒子模型)相对于标准盒子模型,css中设置的宽高属性就盒子而言是指content+padding+border的

推荐文章

热门文章

相关标签