广告
返回顶部
首页 > 资讯 > 后端开发 > Python >python openpyxl的使用方法
  • 920
分享到

python openpyxl的使用方法

pythonopenpyxlopenpyxl的使用 2022-06-02 22:06:33 920人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

目录生成新excel创建Sheet的三种方法给Sheet中某cell赋值赋值cell的值读取Excel加载文件获取sheet一个例子首先创建一个tab页收集数据保存总成绩总结生成新Excel from openp

目录
  • 生成新excel
    • 创建Sheet的三种方法
    • 给Sheet中某cell赋值
    • 赋值cell的值
  • 读取Excel
    • 加载文件
    • 获取sheet
  • 一个例子
    • 首先创建一个tab页
    • 收集数据
    • 保存总成绩
  • 总结

    生成新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.' 所以需要先检查一下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的使用的资料请关注编程网其它相关文章!

    --结束END--

    本文标题: python openpyxl的使用方法

    本文链接: https://www.lsjlt.com/news/11016.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作