【python】关于openpyxl的基本使用方法-看这篇就够了

目录


一、下载安装与引用

pip install openpyxl

import openpyxl

二、创建工作簿并写入数据

创建工作簿

wb= openpyxl.Workbook()

创建工作表

# 创建目录
ws = wb.create_sheet(title, index) 

参数定义:

title:工作表的名称

index:新生成的工作表放在那个位置上

        不填写:默认将新工作表插入到工作簿的最后一个位置

        0:表示将新工作表插入到工作簿的第一个位置

        1:表示将新工作表插入到工作簿的第二个位置

        -1:表示将新工作表插入到工作簿的倒数第二个位置

写入数据

#方法一:
ws.cell(row, column, values)
#方法二:
ws.cell(row,column).value=values
#方法三:
ws['J1']=values
参数定义:

row:工作表的行号,第一行从1开始

column:工作表的列号,第一列从1开始

values:要写入单元格的数据

J1:第J列,第1行

保存数据

wb.save(filename)

其中:filename为要保存成为的文件名,如果文件名带有路径,则文件会保存在对应的路径下

三、读取表格并查找数据

读取表格

wb=openpyxl.load_workbook(filename)

 filemane:可以为文件名,也可以是所对应路径的文件地址

读取指定工作表

ws=wb[sheetname]

重命名指定工作表

ws.title=New_sheetname

获取单元格数据

#方法一:
val=ws.cell(row,column).value
#方法二:
cell_value = ws['A1'].value
#方法三:
ws = wb['用户工作表']
    for row in ws.rows:  # 获取每一行的数据
        for data in row:  # 获取每一行中单元格的数据
            print(data.value)  # 打印单元格的值

 获取第row行,第column列的数据赋值给变量val

四、其他操作 

多个工作表之间的切换

如果有多个工作表,之前如何相互切换 :比如有工作表sheet1、sheet2

打开工作簿默认激活的是第一个工作表sheet1,可以不用设置激活状态了;

但是当你想切换到第二个工作表sheet2;对sheet2里的数据进行操作,则

ws2=wb[sheet2name]

wb.active = ws2

处理行和列

  • 迭代行:for row in ws.iter_rows(min_row=1, min_col=1, max_row=10, max_col=3):
  • 迭代列:for col in ws.iter_cols(min_row=1, min_col=1, max_row=10, max_col=3):
  • 插入行:ws.insert_rows(idx=2, amount=1)
    • ​​​​​ws: 要插入行的工作表
    • idx: 要在哪个位置插入新行,该值为行索引(从1开始)
      • 在第一行前面插入,则idx=1
      • 在第一行后面插入,则idx=2
      • 在第二行后面插入,则idx=3
    • amount: 要插入的行数
  • 删除行:ws.delete_rows(idx=2, amount=1)
    • idx: 要删除的第一行的索引(从1开始)。
    • amount: 要删除的行数。
  • 插入列:ws.insert_cols(idx=2, amount=1)
  • 删除列:ws.delete_cols(idx=2, amount=1)

格式化单元格

  • 设置单元格格式:ws['A1'].number_format = '0.00%'
  • 设置单元格字体:ws['A1'].font = Font(size=12, bold=True)
  • 设置单元格边框:ws['A1'].border = Border(left=Side(border_style='thin', color='FF000000'), right=Side(border_style='thin', color='FF000000'), top=Side(border_style='thin', color='FF000000'), bottom=Side(border_style='thin', color='FF000000'))
  • 合并单元格:ws.merge_cells('A1:B2')
  • 拆分单元格:ws.unmerge_cells('A1:B2')

修改工作表标题背景 

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

 设置单元格颜色和字体

from openpyxl import Workbook
from openpyxl.styles import Font, Color, PatternFill, colors

# 创建一个新工作簿
wb = Workbook()

# 获取活动工作表
ws = wb.active

# 设置第二行第二列单元格的值为“Hello World!”
ws.cell(row=2, column=2).value = 'Hello World!'

#font1 = Font(name="微软雅黑", size=20, bold=True, italic=True, color="FF0000")
# name:字体类型,size:字体大小,bold:是否加粗,italic:是否斜体,color:字体颜色
# 创建字体对象和填充对象
font = Font(color=colors.RED, bold=True)
fill = PatternFill(start_color='FFFF00', end_color='FFFF00', fill_type='solid')

# 将字体和填充应用到单元格
ws.cell(row=2, column=2).font = font
ws.cell(row=2, column=2).fill = fill

# 保存工作簿
wb.save('example.xlsx')


在这个例子中,我们首先创建一个新工作簿并获取活动工作表。然后,我们将第二行第二列单元格的值设置为“Hello World!”。接着,我们创建了一个字体对象和一个填充对象,并将它们应用到单元格。最后,我们保存工作簿。

在这个例子中,我们将字体设置为粗体红色,将填充颜色设置为黄色

文章出处登录后可见!

已经登录?立即刷新

共计人评分,平均

到目前为止还没有投票!成为第一位评论此文章。

(0)
xiaoxingxing的头像xiaoxingxing管理团队
上一篇 2023年9月8日
下一篇 2023年9月8日

相关推荐