Python第三方常用模块openpyxl的简单介绍

作者:XWenXiang 时间:2021-05-28 16:10:09 

openpyxl

openpyxl模块属于第三方模块,是一个在 python 中能够处理 excel 文件的模块,还有比较出名的是xlrd、xlwt 分别控制excel文件的读写,这俩个能够兼容所有版本的文件。openpyxl 针对 excel 2003版本之前的兼容性可能不好 但是功能更加强大。

excel文件的版本及后缀
    2003版本之前 excel的文件后缀是xls
    2003版本之后 excel的文件后缀是xlsx、csv

创建文件

Workbook() —创建 excel 文件

使用 openpyxl 创建文件。只需导入Workbook类

from openpyxl import Workbook
wb = Workbook()
# 一个 excel 文件创建成功

Workbook.create_sheet() —创建 excel 工作簿

Workbook.create_sheet() 可以创建自定义名称的工作簿。括号里的参数是工作簿名称,还有一个参数是工作簿的位置,也可以不写

from openpyxl import Workbook

wb = Workbook()
ws1 = wb.create_sheet('用户信息表', 0)  # 创建了一个用户信息表并放在第一位,如下图

Python第三方常用模块openpyxl的简单介绍

Sheet 工作簿是自动生成的

可以创建多个工作簿,并且它们按顺序排列。

Worksheet.title —给工作簿重命名

使用 Worksheet.title属性更改表名称

from openpyxl import Workbook

wb = Workbook()  # 创建 excel 文件
ws1 = wb.create_sheet('用户信息表', 0)  # 创建工作簿用户信息表放在第一位
ws2 = wb.create_sheet('bank_info')  # 创建工作簿bank_info
ws1.title = 'user_info'  # 更改工作簿用户信息表的名称
'''用代码保存一下后,如下图所示'''

Python第三方常用模块openpyxl的简单介绍

用户信息表 被改名成 user_info

ws.sheet_properties.tabColor = " " 修改标题背景

from openpyxl import Workbook

wb = Workbook()
ws1 = wb.create_sheet('用户信息表', 0)
ws1.sheet_properties.tabColor = 'FF6666'  # 将标题背景改为指定RRGGBB颜色代码
'''用代码保存一下后,如下图所示'''

Python第三方常用模块openpyxl的简单介绍

变得更好看了…

Workbook.sheetname —查看 excel 所有工作簿

返回包含 excel 文件下所有工作簿名称的列表

from openpyxl import Workbook

wb = Workbook()
ws1 = wb.create_sheet('用户信息表', 0)
print(wb.sheetnames)

打印结果 ['用户信息表', 'Sheet']

Workbook.copy_worksheet() —创建工作表的副本

Workbook.copy_worksheet()方法可以在单个工作簿中创建工作表的副本。 仅复制单元格(包括值、样式、超链接和注释)和某些工作表属性(包括尺寸、格式和属性)。不会复制所有其他工作簿/工作表属性 - 例如图像、图表。

获取修改数据

访问一个单元格

在 excel 中可以通过位置找到里面的内容,同样使用代码也能通过位置找到内容。

Worksheet[ ]

from openpyxl import Workbook

wb = Workbook()
ws1 = wb.create_sheet('用户信息表', 0)
ws1['A1'] = 'XWenXiang'  # ws1['A1'] 代表的是该表中的 A1 位置,我们可以将数据直接赋值给它
'''用代码保存一下后,如下图所示'''

Python第三方常用模块openpyxl的简单介绍

此时的 A1 被填入内容 XWenXiang

Worksheet.cell()

----'除了直接获取位置还可以使用 Worksheet.cell()方法'-----

from openpyxl import Workbook

wb = Workbook()
ws1 = wb.create_sheet('用户信息表', 0)
ws1.cell(row=4, column=2, value=10)  

此方法是通过指定坐标的方式赋值,其中 row 参数代表行数, column 代表列数,value 是填入的数据。
'''用代码保存一下后,如下图所示'''

Python第三方常用模块openpyxl的简单介绍

在第2列第4行的位置填入数字10

Worksheet.append()

Worksheet.append() 可以同时写入多个数据。

from openpyxl import Workbook

wb = Workbook()
ws1 = wb.create_sheet('用户信息表', 0)
ws1.append(['name', 'age', 'gender'])
ws1.append(['XWenXiang', '15', 'man'])  # 要用 [] 括起来
'''用代码保存一下后,如下图所示'''

Python第三方常用模块openpyxl的简单介绍

批量写入数据,重复数据还可以加一个循环写入。

公式

模块里使用的公式和 excel 中的公式是一样的

ws1['A6'] = '=sum(A4:A5)' # 对A4和A5进行求和并写入到A6

访问多个单元格

可以使用切片访问单元格范围

x = ws['A1':'C2']
x1 = ws['C']
x2 = ws['C:D']
x3 = ws[10]
x4 = ws[5:10]

Worksheet.values —获取单元格值

from openpyxl import Workbook

wb = Workbook()
ws1 = wb.create_sheet('用户信息表', 0)
ws1.append(['name', 'age', 'gender'])
ws1.append(['XWenXiang', '15', 'man'])

for row in ws1.values:
   print(row)

打印结果:
('name', 'age', 'gender')
('XWenXiang', '15', 'man')

保存文件

保存工作簿最简单、最安全的方法是使用 对象的 Workbook.save() 方法 Workbook。

在前面的代码示例都没有将保存代码加入。

wb = Workbook()
wb.save('balances.xlsx')  # balances.xlsx 是保存的路径,也就是文件名。
编辑完要保存才行。

打开文件

openpyxl.load_workbook() —读取 excel 文件

和 Workbook 写入一样,使用 openpyxl.load_workbook() 可以打开现有工作簿。

from openpyxl import load_workbook  # 导入 load_workbook
wb = load_workbook('ex_a.xlsx', read_only=True, data_only=True)  # ex_a.xlsx是文件名
print(wb.sheetnames)  # 打印所有工作簿的名称

读取工作簿数据

方式一
from openpyxl import load_workbook

wb = load_workbook('ex_a.xlsx', read_only=True, data_only=True)
ws = wb['用户信息表']  # 拿到工作薄对象
print(ws['A1'].value)  # 取出工作薄对象中 A1 位置的值

方式二
from openpyxl import load_workbook

wb = load_workbook('ex_a.xlsx', read_only=True, data_only=True)
ws = wb['用户信息表']
print(ws.cell(row=2, column=1).value)  # 通过行与列的形式来取值

方式三(逐行读取)
from openpyxl import load_workbook

wb = load_workbook('ex_a.xlsx', read_only=True, data_only=True)
ws = wb['用户信息表']
for row in ws.rows:  # 获取每一行的数据
   for data in row:  # 获取每一行中单元格的数据
       print(data.value)  # 打印单元格的值

 总结

来源:https://blog.csdn.net/m0_58987515/article/details/123899353

标签:python,openpyxl,模块
0
投稿

猜你喜欢

  • 初识Firebug 全文 — firebug的使用

    2007-10-23 12:54:00
  • 10 行 Python 代码教你自动发送短信(不想回复工作邮件妙招)

    2021-02-14 05:30:27
  • Python格式化文本段落之textwrap库

    2023-11-23 00:40:56
  • Python基于numpy模块实现回归预测

    2022-11-26 19:25:32
  • 使用Python实现二终端网络可靠度

    2021-03-25 17:39:40
  • 基于python的图片修复程序(实现水印去除)

    2021-07-03 13:35:04
  • python 中pyqt5 树节点点击实现多窗口切换问题

    2021-07-28 06:19:39
  • python正则表达式最详解

    2022-03-13 07:29:47
  • python基本数据类型练习题

    2022-07-21 14:26:26
  • 用JS找出字符串中出现次数最多的字母

    2007-11-12 13:40:00
  • Javascript函数类型判断解决方案

    2009-08-27 15:32:00
  • python闭包与引用以及需要注意的陷阱

    2022-12-13 16:01:15
  • Python 使用 docopt 解析json参数文件过程讲解

    2021-06-30 21:44:00
  • Python爬虫获取页面所有URL链接过程详解

    2022-01-31 10:48:46
  • 在pytorch 中计算精度、回归率、F1 score等指标的实例

    2022-08-10 06:28:18
  • torch.utils.data.DataLoader与迭代器转换操作

    2021-01-18 11:02:34
  • 在Python中通过机器学习实现人体姿势估计

    2022-05-20 13:08:25
  • 在Django的session中使用User对象的方法

    2022-04-23 01:20:07
  • Python项目 基于Scapy实现SYN泛洪攻击的方法

    2023-01-15 01:34:30
  • 使用PYTHON解析Wireshark的PCAP文件方法

    2022-12-26 06:04:00
  • asp之家 网络编程 m.aspxhome.com