Python openpyxl模块读写Excel文件

Python openpyxl模块读写Excel文件

openpyxl是一个用于写入和读取xlsx格式的excel文件的Python模块。

安装openpyxl

1.打开cmd
2. 输入 python -m pip install openpyxl 进行安装
在这里插入图片描述

读写xlsx文件

  1. 导入需要的模块
import os
from openpyxl import Workbook, load_workbook
from openpyxl.styles import Font, Alignment, colors
  1. 读取或新建xlsx文件
# 打开或创建xlsx文件
file_name = 'demo.xlsx'
if os.path.exists(file_name):
    workbook = load_workbook(file_name) # 打开工作簿
    # sheet = workbook['产品测试'] # 获取指定名称表
    sheet = workbook.active # 获取活动表,默认第一张表
else:
    workbook = Workbook() # 新建工作簿
    sheet = workbook.active # 获取活动表,默认第一张表
  1. 将一行数据写入表格
data = ['2023-06-06', '电源板''123456', 'PASS']
sheet.append(data)
  1. 设置单元格格式
font = Font(name='黑体', color='ffc7ce', size=12, bold=True) # 字体、颜色、字号、粗体
align = Alignment(horizontal='center', vertical='center') # 居中对齐
col_width = 20 # 列宽
row = 1
# 设置第一行的单元格格式
for column in range(1, sheet.max_column + 1):
    sheet.cell(row , column).font = font # 设置文字格式
    sheet.cell(row , column).alignment = align # 设置对齐方式
    col_name = chr(ord('A') + column - 1)
    sheet.column_dimensions[col_name].width = col_width # 设置列宽
  1. 实例
import os
from openpyxl import Workbook, load_workbook
from openpyxl.styles import Font, Alignment, colors

# 打开或创建xlsx文件
import os
from openpyxl import Workbook, load_workbook
from openpyxl.styles import Font, Alignment

# 打开或创建xlsx文件
file_name = 'demo.xlsx'
if os.path.exists(file_name):
    workbook = load_workbook(file_name) # 打开工作簿
    # sheet = workbook['产品测试']       # 获取指定名称表
    sheet = workbook.active             # 获取活动表,默认第一张表
else:
    workbook = Workbook()   # 打开工作簿
    sheet = workbook.active # 获取活动表,默认第一张表

    # 添加表头
    tab = ('日期', '产品名称', '产品SN', '测试结果')
    sheet.append(tab) 

    font = Font(name='黑体', color=colors.BLUE, size=12, bold=True) # 字体、颜色、字号、粗体
    align = Alignment(horizontal='center', vertical='center')    # 居中对齐
    col_width = 20 # 列宽
    # 设置表头格式
    for column in range(1, sheet.max_column + 1):
        col_name = chr(ord('A') + column - 1)
        sheet.cell(sheet.max_row, column).font = font       # 设置文字格式
        sheet.cell(sheet.max_row, column).alignment = align # 设置对齐方式
        sheet.column_dimensions[col_name].width = col_width # 设置列宽

all_data = {
	'2023-06-06': [['电源板', '123456', 'PASS'], ['谐波板', '038458', 'FAIL']],
    '2023-06-07': [['电源板', '083888', 'PASS'], ['电源板', '832509', 'PASS']]}
row_data = tuple()

# 追加内容
row_num = sheet.max_row
for date, test_data in all_data.items():
    start_row_num = sheet.max_row + 1
    for data in  test_data:
        row_data = list()
        row_data.append(date)
        row_data += data
        print(row_data)
        sheet.append(row_data)
    sheet.merge_cells(start_row=start_row_num, end_row=sheet.max_row, start_column=1, end_column=1)

# 设置所有写入数据的单元格对齐格式:居中对齐
align = Alignment(horizontal='center', vertical='center')
for row in range(row_num, sheet.max_row + 1):
    for column in range(1, sheet.max_column + 1):
        sheet.cell(row, column).alignment = align

workbook.save(file_name) # 保存
workbook.close()

在这里插入图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值