Python办公自动化【合并单元格-openpyxl、增加图表-openpyxl、合并工作薄-openpyxl、合并多个文件工作薄-openpyxl】(三)-全面详解(学习总结---从入门到深化)(下)

简介: Python办公自动化【合并单元格-openpyxl、增加图表-openpyxl、合并工作薄-openpyxl、合并多个文件工作薄-openpyxl】(三)-全面详解(学习总结---从入门到深化)

Python办公自动化【合并单元格-openpyxl、增加图表-openpyxl、合并工作薄-openpyxl、合并多个文件工作薄-openpyxl】(三)-全面详解(学习总结---从入门到深化)(上):https://developer.aliyun.com/article/1420325


代码

from openpyxl import load_workbook
def merger_file():
  from openpyxl import Workbook,load_workbook
  # 创建一个新的excel文件,用来存储合并好的数据
  wb = Workbook()
  # 激活当前的Sheet
  sh = wb.active
  # 获取文件
  import os
  names = os.listdir('./base_data/销售表')
  for name in names:
    load_path = f'./base_data/销售表/{name}'
    # 读取文件
    tmp_wb = load_workbook(load_path)
    # 激活读取的文件的Sheet
    tmp_sh = tmp_wb.active
    # 获取里面的数据
    for r in range(2,tmp_sh.max_row+1):
      # 建立一个列表来保存数据
      row_data = []
      for c in range(1,tmp_sh.max_column+1):
        # 通过行和列的索引获取数据
        value = tmp_sh.cell(r,c).value
        # 将当前列的数据增加到一行中记录
        row_data.append(value)
      # 将当前行数据增加到新的excel中
      sh.append(row_data)
  # 保存
  wb.save('./create_data/21_合并多个文件.xlsx')
if __name__ == '__main__':
  merger_file()


Excel合并多个文件工作薄-openpyxl



代码

def merger_file():
  from openpyxl import Workbook,load_workbook
  # 创建一个excel文件,用来保存合并的数据
  wb = Workbook()
  # 获取要合并的文件的文件名
  import os
  names = os.listdir('./base_data/销售表')
  # 遍历文件名,依次取出
  for name in names:
    # 拼接excel完整地址
    path = f'./base_data/销售表/{name}'
    # 获取新的创建的Sheet的名称
    sheet_name = name[:-5]
    # 加载要合并的excel文件
    tmp_wb = load_workbook(path)
    # 激活要合 并的excel文件的Sheet
    tmp_sh = tmp_wb.active
    # 在新的excel中创建一个新的Sheet,名称为合并的文件名
    new_sh = wb.create_sheet(sheet_name)
    # 获取行数据
    for r in range(1,tmp_sh.max_row+1):
      # 定义一个列表用来存储当前行的所有数据
      all_data = []
      # 获取列数据
      for c in range(1,tmp_sh.max_column+1):
        value = tmp_sh.cell(r,c).value
        all_data.append(value)
     # 将数据保存到新的excel中
      new_sh.append(all_data)
  # 删除自动生成的Sheet
  del wb['Sheet']
  # 保存新Excel文件修改
  wb.save('./create_data/22_合并多个文件2.xlsx')
if __name__ == '__main__':
  merger_file()


Excel快速生成工资条



代码

def create_excel():
  from openpyxl import load_workbook,Workbook
  # 加载文件,data_only=True代表显示值
  wb = load_workbook('./base_data/工资数据.xlsx',data_only=True)
  sh = wb.active
  # 读取数据-遍历每行数据
  # 建立一个title列表,用于存储标题
  title = []
  for i,r in enumerate(sh.rows):
    # 判断是否第一行数据
    if i == 0:
      for c in r:
        title.append(c.value)
    else:
      row_data=[]
      for c in r:
        row_data.append(c.value)  
      # 创建一个新的excel文件
      new_wb =  Workbook()
      # 激活Sheet
      new_sh = new_wb.active
      # 增加数据
      new_sh.append(title)
      new_sh.append(row_data)
      # 保存数据
 new_wb.save(f'./create_data/gong_zi/{r[1].value}.xlsx')
if __name__ == '__main__':
  create_excel()


Excel一键格行换色



代码

def create_excel():
  from datetime import date
  from openpyxl import Workbook
  from openpyxl.styles import PatternFill
  # 创建一个excel对象
  wb = Workbook()
  # 激活Sheet
  sh = wb.active
  # 增加数据
  rows = [
   ['Date', 'Batch 1', 'Batch 2','Batch 3'],
   [date(2030,12, 1), 40, 30, 25],
   [date(2030,12, 2), 40, 25, 30],
   [date(2030,12, 3), 50, 30, 45],
   [date(2030,12, 4), 30, 25, 40],
   [date(2030,12, 5), 25, 35, 30],
   [date(2030,12, 6), 20, 40, 35],
 ]
  for r in rows:
   sh.append(r)
  # 创建样式
  bg_color = PatternFill('solid',fgColor='AEEEEE')
  # 设置样式
  for r in range(1,sh.max_row+1):
    if r%2==0:
      for c in range(1,sh.max_column+1):
        sh.cell(r,c).fill = bg_color
  # 保存excel文件
  wb.save('./create_data/23_隔行换色.xlsx')
if __name__ == '__main__':
  create_excel()


Excel统计加班时间



代码

def create_excel():
  from datetime import date
  from openpyxl import Workbook
  # 创建excel对象
  wb = Workbook()
  # 激活数据
  sh = wb.active
  # 增加数据
  rows = [
   ['Date', '姓名', '打卡时间'],
   [date(2030,12, 1), '吕小布','18:50'],
   [date(2030,12, 2),'貂的蝉','18:10'],
   [date(2030,12, 3),'刘备','18:02'],
   [date(2030,12, 4),'吕小布','18:50'],
   [date(2030,12, 5), '张飞','19:22'],
   [date(2030,12, 6), '吕小布','18:50'],
 ]
  for row in rows:
    sh.append(row)
  wb.save('./create_data/24_统计加班时间.xlsx')
def statistics():
   from openpyxl import load_workbook,Workbook
  # 读取数据
  wb = load_workbook('./create_data/24_统计加班时间.xlsx')
  sh = wb.active
  # 统计
  data = []
  for row in range(2,sh.max_row+1):
    # 一条完整的数据
    row_data = []
    for col in range(1,sh.max_column+1):
      value = sh.cell(row,col).value
      row_data.append(value)
    # 统计时间
    # 获取时间
    h,m = row_data[2].split(':')
    # 计算时间 从0:00到打卡的时间
    full = int(h)*60 + int(m)
    rs = full - 18*60
    # 将结果保存到最后一列
    row_data.append(rs)
    #------处理时间 显示问题------
    row_data[0] = row_data[0].date()
    data.append(row_data)
  # 保存
  wb = Workbook()
  sh = wb.active
  for d in data:
    sh.append(d)
  wb.save('./create_data/24_统计加班时间.xlsx')
if __name__ == '__main__':
  create_excel()
  statistics()


目录
相关文章
|
3月前
|
数据采集 监控 数据挖掘
Python自动化脚本:高效办公新助手###
本文将带你走进Python自动化脚本的奇妙世界,探索其在提升办公效率中的强大潜力。随着信息技术的飞速发展,重复性工作逐渐被自动化工具取代。Python作为一门简洁而强大的编程语言,凭借其丰富的库支持和易学易用的特点,成为编写自动化脚本的首选。无论是数据处理、文件管理还是网页爬虫,Python都能游刃有余地完成任务,极大地减轻了人工操作的负担。接下来,让我们一起领略Python自动化脚本的魅力,开启高效办公的新篇章。 ###
|
2月前
|
Python Windows
Python实现常用办公文件格式转换
本文介绍了如何使用Python及其相关库(如`pandas`、`openpyxl`、`python-docx`等)实现办公文件格式间的转换,包括XLS转XLSX、DOC转DOCX、PPT转PPTX、Word转PDF及PDF转Word,并提供了具体代码示例和注意事项。
208 89
|
2月前
|
存储 人工智能 人机交互
PC Agent:开源 AI 电脑智能体,自动收集人机交互数据,模拟认知过程实现办公自动化
PC Agent 是上海交通大学与 GAIR 实验室联合推出的智能 AI 系统,能够模拟人类认知过程,自动化执行复杂的数字任务,如组织研究材料、起草报告等,展现了卓越的数据效率和实际应用潜力。
223 1
PC Agent:开源 AI 电脑智能体,自动收集人机交互数据,模拟认知过程实现办公自动化
|
3月前
|
数据采集 IDE 测试技术
Python实现自动化办公:从基础到实践###
【10月更文挑战第21天】 本文将探讨如何利用Python编程语言实现自动化办公,从基础概念到实际操作,涵盖常用库、脚本编写技巧及实战案例。通过本文,读者将掌握使用Python提升工作效率的方法,减少重复性劳动,提高工作质量。 ###
102 1
|
3月前
|
数据管理 程序员 数据处理
利用Python自动化办公:从基础到实践####
本文深入探讨了如何运用Python脚本实现办公自动化,通过具体案例展示了从数据处理、文件管理到邮件发送等常见办公任务的自动化流程。旨在为非程序员提供一份简明扼要的实践指南,帮助他们理解并应用Python在提高工作效率方面的潜力。 ####
|
4月前
|
测试技术 Python
自动化测试项目学习笔记(二):学习各种setup、tearDown、断言方法
本文主要介绍了自动化测试中setup、teardown、断言方法的使用,以及unittest框架中setUp、tearDown、setUpClass和tearDownClass的区别和应用。
133 0
自动化测试项目学习笔记(二):学习各种setup、tearDown、断言方法
|
4月前
|
存储 BI 数据库
使用 Python 实现自动化办公
使用 Python 实现自动化办公
45 0
|
测试技术 Python
python接口自动化测试 - openpyxl基本使用
python接口自动化测试 - openpyxl基本使用
162 0
|
2月前
|
人工智能 数据可视化 数据挖掘
探索Python编程:从基础到高级
在这篇文章中,我们将一起深入探索Python编程的世界。无论你是初学者还是有经验的程序员,都可以从中获得新的知识和技能。我们将从Python的基础语法开始,然后逐步过渡到更复杂的主题,如面向对象编程、异常处理和模块使用。最后,我们将通过一些实际的代码示例,来展示如何应用这些知识解决实际问题。让我们一起开启Python编程的旅程吧!
|
2月前
|
存储 数据采集 人工智能
Python编程入门:从零基础到实战应用
本文是一篇面向初学者的Python编程教程,旨在帮助读者从零开始学习Python编程语言。文章首先介绍了Python的基本概念和特点,然后通过一个简单的例子展示了如何编写Python代码。接下来,文章详细介绍了Python的数据类型、变量、运算符、控制结构、函数等基本语法知识。最后,文章通过一个实战项目——制作一个简单的计算器程序,帮助读者巩固所学知识并提高编程技能。

推荐镜像

更多