python 读取、写入、追加、覆盖xlsx文件
python 读取、写入、追加、覆盖xlsxx文件
0、写在前面
测试源xlsx是这样的
1、读取xlsx
def read_xlsx(filename: str, sheet_name: str) -> List[list]:
filename = os.path.abspath(filename)
assert os.path.isfile(filename), f'{filename} is not file'
assert filename.lower().endswith('.xlsx'), f'不是.xlsx文件:{filename}'
wb: Workbook = openpyxl.load_workbook(filename)
assert sheet_name in wb.sheetnames, "sheet name error"
ws: Worksheet = wb[sheet_name]
all_data = []
for row in ws.rows:
data_row = []
for data in row:
cell: Cell = data
data_row.append(cell.value)
all_data.append(data_row)
print("all data".center(50, '*'))
for one in all_data:
print(one)
return all_data
运行
2、写入xlsx
def write_xlsx(filename: str, sheet_name: str, data: List[list]):
filename = os.path.abspath(filename)
assert filename.lower().endswith('.xlsx'), f'不是.xlsx文件:{filename}'
if not os.path.exists(os.path.dirname(filename)):
os.makedirs(os.path.dirname(filename))
wb: Workbook = openpyxl.Workbook()
sheet: Worksheet = wb.active
sheet.title = sheet_name
for row in data:
sheet.append(row)
wb.save(filename)
print(f"保存到:{filename}")
运行
3、覆盖xlsx
def cover_xlsx(filename: str, sheet_name: str, data: List[list]):
filename = os.path.abspath(filename)
assert os.path.isfile(filename), f'{filename} is not file'
assert filename.lower().endswith('.xlsx'), f'不是.xlsx文件:{filename}'
wb: Workbook = openpyxl.load_workbook(filename)
assert sheet_name in wb.sheetnames, "sheet name error"
ws: Worksheet = wb[sheet_name]
for row_x, row in enumerate(data):
for clo_x, clo in enumerate(row):
ws.cell(row_x + 1, clo_x + 1, clo)
wb.save('over.xlsx')
运行
4、追加xlsx
def append_xlsx(filename: str, sheet_name: str, data: List[list]):
filename = os.path.abspath(filename)
assert os.path.isfile(filename), f'{filename} is not file'
assert filename.lower().endswith('.xlsx'), f'不是.xlsx文件:{filename}'
wb: Workbook = openpyxl.load_workbook(filename)
assert sheet_name in wb.sheetnames, "sheet name error"
ws: Worksheet = wb[sheet_name]
for row in data:
ws.append(row)
wb.save('append.xlsx')
运行
5、代码汇总
import os.path
from typing import List
import openpyxl
from openpyxl.cell import Cell
from openpyxl.workbook import Workbook
from openpyxl.worksheet.worksheet import Worksheet
def read_xlsx(filename: str, sheet_name: str) -> List[list]:
filename = os.path.abspath(filename)
assert os.path.isfile(filename), f'{filename} is not file'
assert filename.lower().endswith('.xlsx'), f'不是.xlsx文件:{filename}'
wb: Workbook = openpyxl.load_workbook(filename)
assert sheet_name in wb.sheetnames, "sheet name error"
ws: Worksheet = wb[sheet_name]
all_data = []
for row in ws.rows:
data_row = []
for data in row:
cell: Cell = data
data_row.append(cell.value)
all_data.append(data_row)
print("all data".center(50, '*'))
for one in all_data:
print(one)
return all_data
def write_xlsx(filename: str, sheet_name: str, data: List[list]):
filename = os.path.abspath(filename)
assert filename.lower().endswith('.xlsx'), f'不是.xlsx文件:{filename}'
if not os.path.exists(os.path.dirname(filename)):
os.makedirs(os.path.dirname(filename))
wb: Workbook = openpyxl.Workbook()
sheet: Worksheet = wb.active
sheet.title = sheet_name
for row in data:
sheet.append(row)
wb.save(filename)
print(f"保存到:{filename}")
def append_xlsx(filename: str, sheet_name: str, data: List[list]):
filename = os.path.abspath(filename)
assert os.path.isfile(filename), f'{filename} is not file'
assert filename.lower().endswith('.xlsx'), f'不是.xlsx文件:{filename}'
wb: Workbook = openpyxl.load_workbook(filename)
assert sheet_name in wb.sheetnames, "sheet name error"
ws: Worksheet = wb[sheet_name]
for row in data:
ws.append(row)
wb.save('append.xlsx')
def cover_xlsx(filename: str, sheet_name: str, data: List[list]):
filename = os.path.abspath(filename)
assert os.path.isfile(filename), f'{filename} is not file'
assert filename.lower().endswith('.xlsx'), f'不是.xlsx文件:{filename}'
wb: Workbook = openpyxl.load_workbook(filename)
assert sheet_name in wb.sheetnames, "sheet name error"
ws: Worksheet = wb[sheet_name]
for row_x, row in enumerate(data):
for clo_x, clo in enumerate(row):
ws.cell(row_x + 1, clo_x + 1, clo)
wb.save('over.xlsx')
def main():
filename = "src.xlsx"
sheet_name = "Sheet1"
all_data = read_xlsx(filename, sheet_name)
write_xlsx('write.xlsx', sheet_name, all_data)
data = [
['a', 'b', 'c', 'd'],
['A', 'B', 'C', 'D']
]
append_xlsx(filename, sheet_name, data)
cover_xlsx(filename, sheet_name, data)
if __name__ == '__main__':
main()
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示