python openpyxl的使用方法

2021-09-16 0 883

生成新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\']

一个例子

python openpyxl的使用方法

我们的目标是将相同考号的数据放入到一行中,并计算总成绩

首先创建一个tab页

这里需要注意直接

ws = wb[\'总成绩\']

肯定不行,因为这时候没有这个tab呢 直接就会报 KeyError: \’Worksheet 总成绩 does not exist.\’ 所以需要先检查一下tab页是否存在

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

保存总成绩

一开始直接用多字段相加

for po, row in enumerate(ws.iter_rows(min_row=2, values_only=True)):
    ws.cell(po + 1, 3, 0 + row[3] + row[4] + row[5] + row[6] + row[7] + row[8] + row[9])

报错如下

ws.cell(po + 1, 3, 0 + row[3] + row[4] + row[5] + row[6] + row[7] + row[8] + row[9])
TypeError: unsupported operand type(s) for +: \'int\' and \'NoneType\'

原因是其中存在NoneType,int和NoneType不能相加。 可以用int(value or 0)来将对应的None, 0, [], \”\”这些Python认为是False的转换为1。

总结

人生苦短,我用 Python,在强大的Python帮助下,我们只需几行代码就可以生成我们想要的Excel。

以上就是python openpyxl的使用方法的详细内容,更多关于python openpyxl的使用的资料请关注自学编程网其它相关文章!

遇见资源网 Python python openpyxl的使用方法 http://www.ox520.com/29191.html

常见问题

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务