Python自动化:xlrd读取excel(python读取excel文件代码)
itomcoil 2025-05-10 22:31 4 浏览
# pip install xlrd
工作簿、工作表相关操作:
import xlrd
# 打开工作簿
people = xlrd.open_workbook('people1.xls')
#xlrd只能打开.xls格式,不能打开.xlsx格式
# 打开.xlsx格式
# pip install xlrd3
# import xlrd3 as xlrd
# people1 = xlrd.open_workbook('people2.xlsx')
# 选择工作表
sheet = people.sheet_by_index(0) #选择第一个工作表,并将其赋值给sheet
sheet2 = people.sheet_by_name('Sheet1') #选择名为Sheet1 的工作表,并将其赋值给sheet2
sheet3 = people.sheets()[0] #选择第一个工作表,并将其赋值给sheet3
#获取工作簿中工作表的数目
sheets_num = people.nsheets
print(sheets_num)
#获取工作簿中工作表名称列表
sheets_names = people.sheet_names()
print(sheets_names)
#获取工作表中有值单元格的行数
nrows = sheet.nrows
print(nrows) #12
#获取工作表中有值单元格的列数
ncols = sheet.ncols
print(ncols) # 5
行相关操作:
# sheet.row(rowx) #获取由该行中所有的单元格对象组成的列表
print(sheet.row(2)) #打印出第3行所有单元格对象组成的列表
# [number:3.0, text:'c', text:'三', text:'他', xldate:45660.0],日期类型的数据打印出来不对
# sheet.row_values(rowx, start_colx=0, end_colx=None) #返回由该行中所有单元格的数据组成的列表
print(sheet.row_values(10)) #打印出第11行数据组成的列表,后面会有空值,直至最大行值
# [11.0, '', '', '', '']
print(sheet.row_values(2,1,5)) # 打印出第3行从第2列-第5列数据组成的列表
# ['c', '三', '他', 45660.0]
# sheet.row_len(rowx) #返回第 行的有值单元格长度
print(sheet.row_len(6)) #打印出第7行的有值单元格长度, 5
列相关操作:
# sheet.col(colx, start_rowx=0, end_rowx=None ) #获取由该列中所有的单元格对象组成的列表
print(sheet.col(3)) #打印出第4列对象组成的列表,后面会有空值,直至最大列值
# [text:'你', text:'我', text:'他', text:'她', text:'它', empty:'', empty:'', empty:'', empty:'', empty:'', empty:'', empty:'']
print(sheet.col(1,1,5)) #打印出第2列从第2行-第5行对象组成的列表
# [text:'b', text:'c', text:'d', text:'e']
# sheet.col_values(colx, start_rowx=0, end_rowx=None) #获取由该列中所有单元格的数据组成的列表
print(sheet.col_values(2)) #打印出第3列数据组成的列表,后面会有空值,直至最长列值
# ['一', '二', '三', '四', '五', '六', '七', '', '', '', '', '']
print(sheet.col_values(2,3,7)) #打印出第3列从第4行-第7行数据组成的列表
# ['四', '五', '六', '七']
单元格相关操作:
# sheet.cell(rowx,colx) #获取单元格对象
print(sheet.cell(3,2)) #打印出C4(第4行第3列), text:'四'
# sheet.cell_value(rowx,colx) #获取单元格的值
print(sheet.cell_value(1,0)) # 打印出A2值(第2行第1列), 2.0
print(sheet.cell_value(0,4)) #打印出E1值(第1行第4列),45658.0,
# 但并没有返回日期2025/1/1,python中没有与工作簿日期类型对应的数据类型
# xlrd.xldate_as_datetime()
print(xlrd.xldate_as_datetime(sheet.cell_value(0,4),0)) # 2025-01-01 00:00:00
遍历所有数据:
for r in range(sheet.nrows):
for c in range(sheet.ncols):
print(f'第{r+1}行,第{c+1}列的数据是:{sheet.cell_value(r,c)}')
参考资料:
《Python办公自动化》,廖茂文
https://www.cnblogs.com/insane-Mr-Li/p/9092619.html
相关推荐
- tkinter.simpledialog:打造Python GUI程序的简单对话框
-
在开发GUI应用程序时,用户交互是一个关键的组成部分。Python的tkinter库提供了丰富的工具来创建图形用户界面,而其中的tkinter.simpledialog模块则是实现交互式对话框的便捷方...
- Python tkinter 学习笔记(一):父窗体和标签控件
-
‘Pythontkinter’是Python自带的GUI工具包,非常适合开发小型的GUI应用。最近使用‘tkinter’开发了一些自己日常使用的小工具,效果不错,于是把开发过程中学习到的一些’tki...
- 好消息!Delphi 的VCL & FMX 图形用户界面库在python中免费使用
-
#春日领好运#也许您在学习python时,大多时候就是计算或者作图,print使用频率较高,metplotlib的库使用频繁,但想编写漂亮的图形界面,怎么办?在Python中编写图形界面(GUI)...
- 用Python打造一个简洁美观的桌面计算器
-
最近在学习PythonGUI编程,顺手用Tkinter实现了一个简易桌面计算器,功能虽然不复杂,但非常适合新手练手。如果你正在学习Python,不妨一起来看看这个项目吧!项目背景Tkint...
- 快速掌握Python GUI编程:Tkinter库窗口和控件布局技巧
-
GUI编程简介:GUI(GraphicalUserInterface,图形用户界面)是一种用户与计算机交互的方式,它通过鼠标、键盘和其他输入设备提供视觉反馈,使用户可以更加直观地操作计算机。GU...
- 基于 Python 的 S7-200 Smart PLC 监控系统开发
-
一、系统概述本监控系统基于Python语言开发,采用Tkinter实现GUI界面,结合snap7库实现与西门子S7-200SmartPLC的通信。系统实现了对工业现场水泵机组、...
- 开发图形界面Tkinter、wxPython、PyQt、PySide选哪一个?
-
学习Python,就不得不提一下Python的图形界面开发,如果只用命令行写程序,用户体验不太好,难以胜任复杂的人机交互场景。Python的图形界面开发库常用的有:Tkinter、wxPython...
- 软件测试|超好用超简单的Python GUI库——tkinter(十四)
-
前言我们知道我们可以使用pillow绘制不同形状的图形,但是我们能不能使用tkinter实现这个功能呢,当然可以,tkinter也可以实现图形的绘制,并且可以将绘制的图形添加到我们的GUI中。我们可以...
- 太绝了!Python新手借助Cursor AI,竟完成了这个超实用音乐盒
-
深度案例解析:Python新手如何用CursorAI从零打造「我的音乐盒」桌面程序在AI技术革新编程范式的当下,Cursor作为智能编程助手,以对话式开发模式显著降低技术门槛。本案例将通过Pytho...
- Python中最好用的GUI工具包
-
根据搜索结果的综合对比,以下是Python中最主流的GUI工具包推荐及适用场景分析,开发者可根据项目需求选择最合适的方案:一、综合能力最强:PyQt5核心优势:基于Qt框架开发,提供超过620个组件和...
- 使用 Python 构建惊人的 GUI!
-
让我们来看看用Python构建令人惊叹的GUI的方法!这种特定的方式是使用CustomTkinter包,这是一个基于Tkinter的现代UI构建器!以下是几个示例:在我看来,这些...
- 在python中用于处理用户界面的方法除了Tkinter外还有哪几种?
-
Python是一种通用编程语言,它本身不直接提供UI(用户界面)功能,也就是说,如果你只安装了python,那恐怕只能用命令行来运行命令,那谁受得了啊。要知道linux就是因为用户界面不够强大,...
- 小白之Tkinter库读文:其他功能-网络功能(51)
-
5.11网络功能说明Tkinter可以通过Python的网络模块实现网络通信功能。常用的网络通信方式包括:使用socket模块:实现底层的网络通信(如TCP/UDP)。使用第三方库(如...
- Python超炫技巧!Tkinter神级应用打造震撼视觉的图形化界面设计
-
目录一、图形化界面设计的基本理解二、窗体控件布局2.1.根窗体显示实例2.2.tkinter常用控件2.2.1控件的共同属性2.3控件布局2.3.1pack()方法2.3.2grid()方...
- Python 内置GUI库Tkinter基本组件课程汇总
-
python现在是越来越火爆,已经渗入了各个行业。现在就连非软件开发人员都开始使用这个门语言来办公了。这门语言是最适合非研发人员学习的语言。平时我们最习惯用的就是双击电脑上的一个exe程序然后就运行程...
- 一周热门
- 最近发表
-
- tkinter.simpledialog:打造Python GUI程序的简单对话框
- Python tkinter 学习笔记(一):父窗体和标签控件
- 好消息!Delphi 的VCL & FMX 图形用户界面库在python中免费使用
- 用Python打造一个简洁美观的桌面计算器
- 快速掌握Python GUI编程:Tkinter库窗口和控件布局技巧
- 基于 Python 的 S7-200 Smart PLC 监控系统开发
- 开发图形界面Tkinter、wxPython、PyQt、PySide选哪一个?
- 软件测试|超好用超简单的Python GUI库——tkinter(十四)
- 太绝了!Python新手借助Cursor AI,竟完成了这个超实用音乐盒
- Python中最好用的GUI工具包
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)