python写入Excel表格的方法详解

 更新时间:2022年02月07日 08:54:54   作者:胜天半月子  
这篇文章主要为大家详细介绍了python写入Excel表格的方法,使用jupyter notebook,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

一、写入Excel数据

週用openpyxl也提供了一些方法写入数据,这意味着你的程序可以创建和编辑电子表格文件。利用Python创建一个包含几千行数据的电子表格是非常简单的。

週用openpyxl.Workbook()函数,创建一个新的空Workbook对象

本章节所有代码均在jupyter notebook中完成

创建一个新的工作簿对象

import openpyxl
wb = openpyxl.Workbook()
wb

<openpyxl.workbook.workbook.Workbook at 0x22473ff4da0>

获取工作表名称

# 查看默认的工作表的名称
wb.sheetnames

[‘Sheet’]

给工作表设置名称

# 查看默认的工作表的名称
wb.sheetnames

[‘跟进记录表’]

保存工作表

wb.save('./data/第一个工作簿.xlsx') # 需要给路径地址

在这里插入图片描述

创建和删除工作表

  • 利用create_sheet 和del语法,可以在工作簿中添加或删除工作表,
  • 在工作簿中添加或删除工作表之后,记得调用save()方法来保存变更。

创建sheet

wb = openpyxl.load_workbook('./data/第一个工作簿.xlsx')
wb.create_sheet(title='销售记录')

<Worksheet “销售记录”>

wb.sheetnames

[‘跟进记录表’, ‘销售记录’]

wb.create_sheet(index=1,title='养殖技术') # index表示新创建的工作簿放在第几个位置   index从0开始计数

<Worksheet “养殖技术”>

wb.sheetnames  # 0 1 2 从0开始计数

[‘跟进记录表’, ‘养殖技术’, ‘销售记录’]

删除sheet表

del wb['养殖技术']
wb.sheetnames 

[‘跟进记录表’, ‘销售记录’]

wb.save('./data/第一个工作簿.xlsx')

在这里插入图片描述

千万记住:只有save()后打开Excel表格你做的操作才会显示

将值写入单元格

  • 将值写入单元格,很像将值写入字典中的键
  • 如果你有单元格坐标的字符串,可以像字典的键一样,将它用于Worksheet对象,指定要写入的单元格。
  • 最后使用save()进行保存
sheet = wb['销售记录'] 
sheet['A1'] = 'HELLO'
sheet['B2'] = 'world'
wb.save('./data/第一个工作簿.xlsx')  # 操作之后一定要保存

在这里插入图片描述

二、项目:更新一个电子表格

2.1 案例需求

获取资源:produceSales.xlsx 提取码: ge7k

这个项目需要编写一个程序,更新产品销售电子表格中的单元格,程序将遍历这个电子表格,找到特定类型的产品,并更新它们的价格

数据说明

  • 每一行代表一次单独的销售。列分别是销售产品的类型(A)、产品每磅的价格(B)、销售的磅数(C),以及这次销售的总收入(D).TOTAL列已经设置为Excel公式,将每磅的成本乘以销售的磅数,并将结果取整到分。有了这个公式,如果列B或C发生变化,TOTAL列中的单元格将自动更新
  • 现在假设Garlic,Celery和Lemons的价格输入的不正确。这让你面对一项无聊的任务:遍历这个电子表格中的几万行,更新所有garlic.celery和lemon行中每磅的价格。你不能简单地对价格查找替换,因为可能有其他的产品价格一样,你不希望错误地"更正"。对于几万行数据,手工操作可能要几小时。但你可以编写程序,几秒钟内完成这个任务。

你的程序做下面的事情

  • 循环追历所有行。
  • 如果该行是Garlic,Celery或Lemons,更新价格。

这意味着代码需要做下面的事情:

  • 打开电子表格文件。
  • 针对每一行,检查列A的值是不是Celery,Garlic或Lemon,如果是,更新列B中的价格。将该电子表格保存为一个新文件(这样就不会丢失原来的电子表格,以防万一)

需要更新的价格如下

  • Celery 1.19
  • Garlic 3.07
  • Lemon 1.27

在这里插入图片描述

2.2 案例源码

import openpyxl
print('openning...')
wb = openpyxl.load_workbook('./data/produceSales.xlsx')
sheet = wb['Sheet']
 
# The produce types and their updated prices
PRICE_UPDATES = {'Garlic': 3.07,
                 'Celery': 1.19,
                 'Lemon': 1.27}
 
# Loop through the rows and update the prices.
for rowNum in range(2, sheet.max_row + 1):
    # 取出第一列商品的名称
    produceName = sheet.cell(row=rowNum, column=1).value
    # 如果取出的商品名称在字典中 则需要修改
    if produceName in PRICE_UPDATES:
        sheet.cell(row=rowNum, column=2).value = PRICE_UPDATES[produceName]


wb.save('./data/updateProduceSales.xlsx')
print('finishing...')

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容! 

相关文章

  • Django定制Admin页面详细实例(展示页面和编辑页面)

    Django定制Admin页面详细实例(展示页面和编辑页面)

    django自带的admin因为功能和样式比较简陋,常常需要再次定制,下面这篇文章主要给大家介绍了关于Django定制Admin页面(展示页面和编辑页面)的相关资料,需要的朋友可以参考下
    2023-06-06
  • Python 分支结构详解

    Python 分支结构详解

    这篇文章主要介绍了Python 分支结构,分支结构包括单分支结构、双分支结构、多分支结构等内容,下文ui分支结构进行详细分析,需要的小伙伴可以参考一下
    2022-02-02
  • python 浅谈serial与stm32通信的编码问题

    python 浅谈serial与stm32通信的编码问题

    今天小编就为大家分享一篇python 浅谈serial与stm32通信的编码问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-12-12
  • Python小进度条显示代码

    Python小进度条显示代码

    今天小编就为大家分享一篇关于Python小进度条显示代码,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • pycharm中jupyter的使用图文教程

    pycharm中jupyter的使用图文教程

    这篇文章主要介绍了pycharm中jupyter的使用图文教程,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-05-05
  • python智联招聘爬虫并导入到excel代码实例

    python智联招聘爬虫并导入到excel代码实例

    这篇文章主要介绍了python智联招聘爬虫并导入到excel代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-09-09
  • 深入理解Python变量与常量

    深入理解Python变量与常量

    下面小编就为大家带来一篇深入理解Python变量与常量。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-06-06
  • Python搭建代理IP池实现存储IP的方法

    Python搭建代理IP池实现存储IP的方法

    这篇文章主要介绍了Python搭建代理IP池实现存储IP的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10
  • 带你从内存的角度看Python中的变量

    带你从内存的角度看Python中的变量

    这篇文章主要为大家介绍了从内存的角度看Python中的变量,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-01-01
  • Python Django教程之实现待办事项应用程序

    Python Django教程之实现待办事项应用程序

    Django是一个基于Python Web框架的高级Web框架,允许快速开发和干净,务实的设计。本文将创建一个待办事项应用程序,以了解Django的基础知识,感兴趣的可以尝试一下
    2022-10-10

最新评论