生成新Excel
from openpyxl import Workbook from openpyxl.utils import get_column_letter wb = Workbook() dest_filename = 'empty_book.xlsx' ws1 = wb.active ws1.title = "range names" for row in range(1, 40): ws1.append(range(600)) ws2 = wb.create_sheet(title="Pi") ws2['F5'] = 3.14 ws3 = wb.create_sheet(title="Data") for row in range(10, 20): for col in range(27, 54): _ = ws3.cell(column=col, row=row, value="{0}".format(get_column_letter(col))) print(ws3['AA10'].value) wb.save(filename=dest_filename)
一共创建了三个Sheet
创建Sheet的三种方法
ws1 = wb.create_sheet("Mysheet") # 在末尾添加 # or ws2 = wb.create_sheet("Mysheet", 0) # 在开头添加 # or ws3 = wb.create_sheet("Mysheet", -1) # 在倒数第二位添加
给Sheet中某cell赋值
ws2['F5'] = 3.14
赋值cell的值
ws3.cell(column=col, row=row, value="{0}".format(get_column_letter(col)))
读取Excel
from openpyxl import load_workbook wb = load_workbook(filename = 'empty_book.xlsx') sheet_ranges = wb['range names'] print(sheet_ranges['D18'].value)
加载文件
wb = load_workbook(filename = 'empty_book.xlsx')
获取sheet
sheet_ranges = wb['range names']
一个例子
我们的目标是将相同考号的数据放入到一行中,并计算总成绩
首先创建一个tab页
这里需要注意直接
ws = wb['总成绩']
肯定不行,因为这时候没有这个tab呢 直接就会报 KeyError: ‘Worksheet 总成绩 does not exist.’ 所以需要先检查一下ta本文来源[email protected]搞@^&代*@码)网9b页是否存在
if not '总成绩' in wb.sheetnames: wb.create_sheet('总成绩') ws = wb['总成绩']
需要注意的是最后一定要进行保存操作,否则无用 wb.save(‘first.xlsx’)
收集数据
# 对每个tab中的分数数据进行收集,放入对应的数据行中 for pos, tabName in enumerate(wb.sheetnames): if tabName != '总成绩': wstt = wb[tabName] for row in wstt.iter_rows(min_row=2, values_only=True): for ind, code in enumerate(ws['A']): if code.value == row[0]: ws.cell(ind + 1, 4 + pos, row[2]) break