Python实例篇:自动操作Excel文件(既简单又特别实用)

简介: Python实例篇:自动操作Excel文件(既简单又特别实用)

前言
大家好,我是辣条哥~

大家平时在工作与学习中都会操作到Excel文件格式,特别是很多数据的时候,靠人力去识别操作非常容易出错。今天就带大家用Python来处理Excel文件,让你成为一个别人眼中的秀儿~

这已经是辣条发布的第114篇博文了,也有很多人留言说想要我的源码,还有想让我带的,奈何我也时间有限,不过能帮的就是我之前也收集了很多的源码,PDF,视频这些,想要的可以直接找我:《单击蓝字直接找我》

目录
前言
工具
读取Excel文件内容
写入Excel文件内容
Excel文件样式调整
总结
工具
python3.7

Pycharm

Excel

xlwt&xlrd

读取Excel文件内容
​ 当前文件夹下有一个名为“股票数据.xlsx”的Excel文件,可以按照下列代码方式来操作它。

import xlrd

使用xlrd模块的open_workbook函数打开指定Excel文件并获得Book对象(工作簿)

wb = xlrd.open_workbook('股票数据.xlsx')

通过Book对象的sheet_names方法可以获取所有表单名称

sheetname = wb.sheet_names()[0]

通过指定的表单名称获取Sheet对象(工作表)

sheet = wb.sheet_by_name(sheetname)

通过Sheet对象的nrows和ncols属性获取表单的行数和列数

print(sheet.nrows, sheet.ncols)
for row in range(sheet.nrows):

for col in range(sheet.ncols):
    # 通过Sheet对象的cell方法获取指定Cell对象(单元格)
    # 通过Cell对象的value属性获取单元格中的值
    value = sheet.cell(row, col).value
    # 对除首行外的其他行进行数据格式化处理
    if row > 0:
        # 第1列的xldate类型先转成元组再格式化为“年月日”的格式
        if col == 0:
            # xldate_as_tuple函数的第二个参数只有0和1两个取值
            # 其中0代表以1900-01-01为基准的日期,1代表以1904-01-01为基准的日期
            value = xlrd.xldate_as_tuple(value, 0)
            value = f'{value[0]}年{value[1]:>02d}月{value[2]:>02d}日'
        # 其他列的number类型处理成小数点后保留两位有效数字的浮点数
        else:
            value = f'{value:.2f}'
    print(value, end='\t')
print()

获取最后一个单元格的数据类型

0 - 空值,1 - 字符串,2 - 数字,3 - 日期,4 - 布尔,5 - 错误

last_cell_type = sheet.cell_type(sheet.nrows - 1, sheet.ncols - 1)
print(last_cell_type)

获取第一行的值(列表)

print(sheet.row_values(0))

获取指定行指定列范围的数据(列表)

第一个参数代表行索引,第二个和第三个参数代表列的开始(含)和结束(不含)索引

print(sheet.row_slice(3, 0, 5))

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
写入Excel文件内容
​ Excel文件写入可以通过xlwt 模块的Workbook类创建工作簿对象,通过工作簿对象的add_sheet方法可以添加工作表,通过工作表对象的write方法可以向指定单元格中写入数据,最后通过工作簿对象的save方法将工作簿写入到指定的文件或内存中。下面代码操作了一个学员成绩表的写入。

import random

import xlwt

student_names = ['关羽', '张飞', '赵云', '马超', '黄忠']
scores = [[random.randint(40, 100) for in range(3)] for in range(5)]

创建工作簿对象(Workbook)

wb = xlwt.Workbook()

创建工作表对象(Worksheet)

sheet = wb.add_sheet('一年级二班')

添加表头数据

titles = ('姓名', '语文', '数学', '英语')
for index, title in enumerate(titles):

sheet.write(0, index, title)

将学生姓名和考试成绩写入单元格

for row in range(len(scores)):

sheet.write(row + 1, 0, student_names[row])
for col in range(len(scores[row])):
    sheet.write(row + 1, col + 1, scores[row][col])

保存Excel工作簿

wb.save('考试成绩表.xlsx')

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
Excel文件样式调整
​ 还可以通过XFStyle对象来设置单元格的不同样式。主要包括字体(Font)、对齐方式(Alignment)、边框(Border)和背景(Background)的设置。

header_style = xlwt.XFStyle()
pattern = xlwt.Pattern()
pattern.pattern = xlwt.Pattern.SOLID_PATTERN

0 - 黑色、1 - 白色、2 - 红色、3 - 绿色、4 - 蓝色、5 - 黄色、6 - 粉色、7 - 青色

pattern.pattern_fore_colour = 5
header_style.pattern = pattern
titles = ('姓名', '语文', '数学', '英语')
for index, title in enumerate(titles):

sheet.write(0, index, title, header_style)

1
2
3
4
5
6
7
8
9
设置表头的位置

align = xlwt.Alignment()

垂直方向的对齐方式

align.vert = xlwt.Alignment.VERT_CENTER

水平方向的对齐方式

align.horz = xlwt.Alignment.HORZ_CENTER
header_style.alignment = align
1
2
3
4
5
6
设置单元格的宽高

设置行高为40px

sheet.row(0).set_style(xlwt.easyxf(f'font:height {20 * 40}'))
titles = ('姓名', '语文', '数学', '英语')
for index, title in enumerate(titles):

# 设置列宽为200px
sheet.col(index).width = 20 * 200
# 设置单元格的数据和样式
sheet.write(0, index, title, header_style)

1
2
3
4
5
6
7
8
总结
​ 其他操作Excel文件的三方库(如openpyxl)大家有兴趣可以自行了解。掌握了Python程序操作Excel的方法,可以解决日常办公中很多繁琐的处理Excel电子表格工作,最常见就是将多个数据格式相同的Excel文件合并到一个文件以及从多个Excel文件或表单中提取指定的数据。当然,如果要对表格数据进行处理,使用Python数据分析神器之一的pandas库可能更为方便,因为pandas库封装的函数以及DataFrame类可以完成大多数数据处理的任务。

目录
相关文章
|
1月前
|
数据采集 数据可视化 数据挖掘
利用Python自动化处理Excel数据:从基础到进阶####
本文旨在为读者提供一个全面的指南,通过Python编程语言实现Excel数据的自动化处理。无论你是初学者还是有经验的开发者,本文都将帮助你掌握Pandas和openpyxl这两个强大的库,从而提升数据处理的效率和准确性。我们将从环境设置开始,逐步深入到数据读取、清洗、分析和可视化等各个环节,最终实现一个实际的自动化项目案例。 ####
124 10
|
6天前
|
前端开发 搜索推荐 编译器
【01】python开发之实例开发讲解-如何获取影视网站中经过保护后的视频-用python如何下载无法下载的视频资源含m3u8-python插件之dlp-举例几种-详解优雅草央千澈
【01】python开发之实例开发讲解-如何获取影视网站中经过保护后的视频-用python如何下载无法下载的视频资源含m3u8-python插件之dlp-举例几种-详解优雅草央千澈
【01】python开发之实例开发讲解-如何获取影视网站中经过保护后的视频-用python如何下载无法下载的视频资源含m3u8-python插件之dlp-举例几种-详解优雅草央千澈
|
9天前
|
人工智能 自然语言处理 Java
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
FastExcel 是一款基于 Java 的高性能 Excel 处理工具,专注于优化大规模数据处理,提供简洁易用的 API 和流式操作能力,支持从 EasyExcel 无缝迁移。
67 9
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
|
3天前
|
存储 算法 Serverless
剖析文件共享工具背后的Python哈希表算法奥秘
在数字化时代,文件共享工具不可或缺。哈希表算法通过将文件名或哈希值映射到存储位置,实现快速检索与高效管理。Python中的哈希表可用于创建简易文件索引,支持快速插入和查找文件路径。哈希表不仅提升了文件定位速度,还优化了存储管理和多节点数据一致性,确保文件共享工具高效运行,满足多用户并发需求,推动文件共享领域向更高效、便捷的方向发展。
|
5天前
|
数据可视化 数据挖掘 大数据
1.1 学习Python操作Excel的必要性
学习Python操作Excel在当今数据驱动的商业环境中至关重要。Python能处理大规模数据集,突破Excel行数限制;提供丰富的库实现复杂数据分析和自动化任务,显著提高效率。掌握这项技能不仅能提升个人能力,还能为企业带来价值,减少人为错误,提高决策效率。推荐从基础语法、Excel操作库开始学习,逐步进阶到数据可视化和自动化报表系统。通过实际项目巩固知识,关注新技术,为职业发展奠定坚实基础。
|
6天前
|
人工智能 编译器 Python
python已经安装有其他用途如何用hbuilerx配置环境-附带实例demo-python开发入门之hbuilderx编译器如何配置python环境—hbuilderx配置python环境优雅草央千澈
python已经安装有其他用途如何用hbuilerx配置环境-附带实例demo-python开发入门之hbuilderx编译器如何配置python环境—hbuilderx配置python环境优雅草央千澈
python已经安装有其他用途如何用hbuilerx配置环境-附带实例demo-python开发入门之hbuilderx编译器如何配置python环境—hbuilderx配置python环境优雅草央千澈
|
1月前
|
Python
按条件将Excel文件拆分到不同的工作表
使用Python的pandas库,可以轻松将Excel文件按条件拆分到不同的工作表中。本文通过一个示例代码展示了如何生成一个包含总成绩表和三个班级表的Excel文件。代码首先创建了一个包含学生姓名、班级和各科成绩的数据框,然后按班级分组,将每个班级的数据分别写入不同的工作表。最后,生成的Excel文件将包含四个工作表,分别为总成绩表和三个班级的成绩表。
34 6
按条件将Excel文件拆分到不同的工作表
|
20天前
|
数据挖掘 vr&ar C++
让UE自动运行Python脚本:实现与实例解析
本文介绍如何配置Unreal Engine(UE)以自动运行Python脚本,提高开发效率。通过安装Python、配置UE环境及使用第三方插件,实现Python与UE的集成。结合蓝图和C++示例,展示自动化任务处理、关卡生成及数据分析等应用场景。
88 5
|
24天前
|
计算机视觉 Python
如何使用Python将TS文件转换为MP4
本文介绍了如何使用Python和FFmpeg将TS文件转换为MP4文件。首先需要安装Python和FFmpeg,然后通过`subprocess`模块调用FFmpeg命令,实现文件格式的转换。代码示例展示了具体的操作步骤,包括检查文件存在性、构建FFmpeg命令和执行转换过程。
41 7
|
1月前
|
Python
批量将不同的工作簿合并到同一个Excel文件
本文介绍如何使用Python的`pandas`库批量合并不同工作簿至同一Excel文件。通过模拟生成三个班级的成绩数据,分别保存为Excel文件,再将这些文件合并成一个包含所有班级成绩的总成绩单。步骤包括安装必要库、生成数据、保存与合并工作簿。
48 6
下一篇
开通oss服务