Python:如何实现对表格的自动化

前情提要:需要有openpyxl哦 如果没有请参考上一篇文章

http://t.csdnimg.cn/fjbLJ
先介绍一下对表格的基本操作 首先创立一个

transactions.xlsx

基本操作:获取表格,获取值

import openpyxl as xl

这个as 单纯简化 相当于别名

wb=xl.load_workbook('transactions.xlsx')

wb['Sheet1']返回一张表格

sheet=wb['Sheet1']

访问第一列第一行两种访问方式

a2表示a行第几列 从一开始 不区分大小写

cell=sheet['a2']

a,b 表示a行b列 从一开始

cell2=sheet.cell(1,2)

获取值

print(cell.value)

print(cell2.value)

获取行

row=sheet.max_row

怎么实现这样变那样呢!

复制代码
import openpyxl as xl
# 这个as 单纯简化 相当于别名
from openpyxl.chart import  BarChart,Reference
# 画图


wb=xl.load_workbook('transactions.xlsx')
# wb['Sheet1']返回一张表格
sheet=wb['Sheet1']

# 获取行
row=sheet.max_row
for i in range(2,row+1):
    cell=sheet.cell(i,3)
    corrected_price=cell.value*0.9
    corrected_price_cell=sheet.cell(i,4)
    corrected_price_cell.value=corrected_price

# 制图开始
# 获取第四例,从第二行到第四行的值
values=Reference(sheet,
          min_row=2,
          max_row=row,
          min_col=4,
          max_col=4)
chart=BarChart()
chart.add_data((values))
# 把图放到e2的位置
sheet.add_chart(chart,'e2')
# 保存表格 避免出错直接写一个新的名字
wb.save('transaction2.xlsx')

如何实现自动化呢!?当然是函数function

复制代码
import openpyxl as xl
from openpyxl.chart import  BarChart,Reference

def process_workbook(filename):
    wb = xl.load_workbook(filename)
    sheet = wb['Sheet1']
    row = sheet.max_row
    for i in range(2, row + 1):
        cell = sheet.cell(i, 3)
        corrected_price = cell.value * 0.9
        corrected_price_cell = sheet.cell(i, 4)
        corrected_price_cell.value = corrected_price

    # 制图开始
    # 获取第四例,从第二行到第四行的值
    values = Reference(sheet,
                       min_row=2,
                       max_row=row,
                       min_col=4,
                       max_col=4)
    chart = BarChart()
    chart.add_data((values))
    # 把图放到e2的位置
    sheet.add_chart(chart, 'e2')
    # 保存表格 避免出错直接写一个新的名字
    wb.save(filename)
相关推荐
聆风吟º4 小时前
CANN开源项目深度实践:基于amct-toolkit实现自动化模型量化与精度保障策略
运维·开源·自动化·cann
较劲男子汉7 小时前
CANN Runtime零拷贝传输技术源码实战 彻底打通Host与Device的数据传输壁垒
运维·服务器·数据库·cann
风流倜傥唐伯虎7 小时前
Spring Boot Jar包生产级启停脚本
java·运维·spring boot
Doro再努力7 小时前
【Linux操作系统10】Makefile深度解析:从依赖推导到有效编译
android·linux·运维·服务器·编辑器·vim
senijusene7 小时前
Linux软件编程:IO编程,标准IO(1)
linux·运维·服务器
忧郁的橙子.8 小时前
02-本地部署Ollama、Python
linux·运维·服务器
醇氧8 小时前
【linux】查看发行版信息
linux·运维·服务器
No8g攻城狮8 小时前
【Linux】Windows11 安装 WSL2 并运行 Ubuntu 22.04 详细操作步骤
linux·运维·ubuntu
做人不要太理性9 小时前
CANN Runtime 运行时与维测组件:异构任务调度、显存池管理与全链路异常诊断机制解析
人工智能·自动化
酷酷的崽7989 小时前
CANN 生态可维护性与可观测性:构建生产级边缘 AI 系统的运维体系
运维·人工智能