python openpyxl的使用方法
from openpyxl import Workbookfrom openpyxl.utils import get_column_letterwb = Workbook()dest_filename = ’empty_book.xlsx’ws1 = wb.activews1.title = 'range names'for row in range(1, 40): ws1.append(range(600))ws2 = wb.create_sheet(title='Pi')ws2[’F5’] = 3.14ws3 = 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') # 在末尾添加# orws2 = wb.create_sheet('Mysheet', 0) # 在开头添加# orws3 = 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_workbookwb = 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.’ 所以需要先检查一下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的使用的资料请关注好吧啦网其它相关文章!
相关文章:
1. 在 XSL/XSLT 中实现随机排序2. Vue Element UI 表单自定义校验规则及使用3. XML在语音合成中的应用4. CSS Hack大全-教你如何区分出IE6-IE10、FireFox、Chrome、Opera5. asp(vbs)Rs.Open和Conn.Execute的详解和区别及&H0001的说明6. JavaScript避免嵌套代码浅析7. 《CSS3实战》笔记--渐变设计(一)8. 用css截取字符的几种方法详解(css排版隐藏溢出文本)9. chatGPT教我写compose函数的详细过程10. CSS3实例分享之多重背景的实现(Multiple backgrounds)