Python openpyxl文档

openpyxl库

记录我自己对这个库的理解用法。
openpyxl 是用于读写 Excel xlsx/xlsm/xltx/xltm 文件的第三方模块。
官方文档传送门

安装方法:

pip install openpyxl

引用库

import openpyxl

打开、创建excel工作簿

# 使用openpyxl创建excel
# Workbook.Workbook()
file = openpyxl.Workbook()
# 使用openpyxl打开excel
# Workbook.load_workbook(str filename)
file = openpyxl.load_workbook("text.xlsx")

打开、创建excel工作表

# 打开工作表(默认为第一个工作表)
ws = file.active
'''
你可以用`Workbook.create_sheet()`方法创建一个新的工作表
该方法有两个参数 第一个为新工作簿名字 第二个为表创建的位置
'''
ws = file.create_sheet("Mysheet") # 在最后的位置插入新的工作簿(default)
ws1 = file.create_sheet("Mysheet", 0) # 在第一个位置插入
ws2 = file.create_sheet("Mysheet", -1) # 在倒数第二个位置插入

访问、查找excel工作表

# 你可以使用Worksheet.title方法给工作簿改名
ws.title = "New Title"

# 你可以使用Worksheet.sheet_properties.tabColor方法给tab标签改颜色
# 颜色格式为十六进制的RGB
# ws.sheet_properties.tabColor = "1072BA"

# 一旦你给了工作表一个名字,那么这个名字就可以作为工作簿的键
ws = file['New Title']

# 你可以用Workbook.sheetname方法查看工作簿中所有工作表的名字
print(file.sheetnames)
# 输出结果为:
['Sheet2', 'New Title', 'Sheet1']

# 你也可以用循环遍历所有的工作表
for sheet in file:
    print(sheet.title)
    
# 你可以用Workbook.copy_worksheet()方法创建工作表的副本
source = file.active
target = file.copy_worksheet(source)
'''注!
只能复制单元格(包括值、样式、超链接和注释)和某些工作表属性(包括维度、格式和属性)。
所有其他工作簿/工作表属性不被复制-例如图像,图表。
也不能在工作簿之间复制工作表。
如果工作簿以只读或仅写模式打开,则无法复制工作表。
'''

获取excel工作表的信息

# 获取工作表的行数、列数
rows = ws.max_row
clol = ws.max_column

# 可以获取特定行或特定列的数据
for cell in list(ws.rows)[0]:
    print(cell.value, end=" ")
for cell in list(ws.columns)[0]:
    print(cell.value, end=" ")

# 可以获取某一块的数据 有两种方法
# 若转为列表 索引从0开始 
# 若用单格访问 则索引从1开始
for rows in list(ws.rows)[0:3]:
    for cell in rows[0:3]:
        print(cell.value, end=" ")
    print()
for i in range(1, 4):
    for j in range(1, 4):
        print(ws.cell(row=i, column=j).value, end=" ")
    print()
# 或者:
cell_range = ws['A1':'C2']
# 或者:
ws.iter_rows(min_row=?, max_row=?, max_col=?) # 行优先遍历
ws.iter_rows(min_row=?, max_row=?, max_col=?) # 列优先遍历

# Worksheet.rows、Worksheet.columns是两个迭代器
# 存的是工作表中的每一行、每一列数据
for row in ws.rows:
    for cell in row:
        print(cell.value, end=" ")
for col in ws.colums:
    for cell in col:
        print(cell.value, end=" ")

修改excel工作表

# 现在我们知道了如何获得工作表,我们可以开始修改单元格内容。
# 单元格可以作为工作表的键直接访问:
# 此方法可以返回'A4'单元格的对象 当此单元格为被创建则会创建 值可以被设置
c = ws['A10']
ws['A10'] = 4
# 也可以使用Worksheet.cell()方法访问
# Worksheet.cell()既可以访问也可以写入
d = ws.cell(row=10, column=2, value=10)

# Worksheet.append()方法 会覆盖当前已有的数据 可添加行
ws.append([' ', ' ', ...])
# 可添加多个参数 各参数为第1列、第2列...

保存excel工作表

# 对表操作之后进行保存
file.save("text.xlsx")

# 若需要保存到stream中时 比如Web程序等 可以使用NamedTemporaryFile()
# NamedTemporaryFile方法在tempfile库中
'''
wb = Workbook()
with tempfile.NamedTemporaryFile() as tmp:
    wb.save(tmp.name)
    tmp.seek(0)
    stream.temp.read()
or    
wb = load_workbook('filename.xlsx')
wb.template = True
wb.save('filename.xltx')
or
wb = load_workbook('filename.xlsx')
wb.template = False
wb.save('filename.xltx', as_template=False)
'''

以上。

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
Pythonopenpyxl是一个用于读取和写入Excel文件的库。您可以使用它来操作Excel文件,包括创建、修改和保存工作簿、工作表以及单元格数据。它提供了一些强大的功能,如数据筛选、图表生成等。您可以使用openpyxl来处理各种Excel文件,包括.xlsx和.xlsm格式的文件。 要开始使用openpyxl,您需要先安装它。您可以使用pip包管理器在命令行中运行以下命令来安装openpyxl: ``` pip install openpyxl ``` 一旦安装完成,您就可以在Python脚本中导入openpyxl模块并开始使用它来读取和写入Excel文件。以下是一个简单的示例代码,演示如何使用openpyxl读取和写入Excel文件: ```python import openpyxl # 打开工作簿 workbook = openpyxl.load_workbook('example.xlsx') # 获取工作表 sheet = workbook['Sheet1'] # 读取单元格数据 cell_value = sheet['A1'].value print(cell_value) # 写入单元格数据 sheet['B1'] = 'Hello, World!' # 保存工作簿 workbook.save('example.xlsx') ``` 在上面的示例中,我们首先打开一个名为"example.xlsx"的Excel文件,并获取名为"Sheet1"的工作表。然后,我们读取了单元格A1的数据,并将其打印出来。接下来,我们在B1单元格中写入了"Hello, World!",最后保存了工作簿。 这只是openpyxl的一小部分功能,您可以在官方文档中找到更多详细的使用说明和示例代码。希望这可以帮助您开始使用openpyxl来处理Excel文件!如果您有任何进一步的问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Raoxiaomi.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值