Python办公自动化【Excel查询重复数据、Excel提取身份证号信息、Python操作Excel模块库文档、Python操作Word基础 】(四)-全面详解(学习总结---从入门到深化)

简介: Python办公自动化【Excel查询重复数据、Excel提取身份证号信息、Python操作Excel模块库文档、Python操作Word基础 】(四)-全面详解(学习总结---从入门到深化)

Excel查询重复数据



代码

def search_data():
  from openpyxl import load_workbook
  # 加载文件
  wb = load_workbook('./base_data/打卡时间.xlsx')
  # 激活Sheet
  sh = wb.active
  # 建立已经读过数据列表
  data = []
  # 建立重复数据列表
  index = []
  # 读取数据
  for i,c in enumerate(sh['B']):
    # 记录是否重复
    # if c.value in data:
    #   flag = True
    # else:
    #   flag = False
    flag = c.value in data
    if flag:
      index.append(i)
    else:
      data.append(c.value)
  # 处理重复数据
  from openpyxl.styles import PatternFill
  fill = PatternFill('solid',fgColor='AEEEEE')
  for i,r in enumerate(sh.rows):
    # 判断是否是重复索引行
    if i in index:
      for c in r:
        c.fill = fill
  # 保存数据
  wb.save('./create_data/25_打卡时间_重复检测.xlsx')
if __name__ =='__main__':
  search_data()


Excel提取身份证号信息



代码

def get_data():
  from openpyxl import load_workbook
  # 加载文件
  wb = load_workbook('./base_data/人员信息.xlsx')
  # 激活Sheet
  sh = wb.active
  # 获取Sheet中最后一列是多少
  max_col = sh.max_column
  # 读取数据-只读取一列-遍历每一行获取具体数据
  for i,cell in enumerate(sh['B']):
    # 从身份证号里提取内容- 6位行政区划 4年 2月 2日 4位个人数字
    pno = cell.value
    # 年
    year = pno[6:10]
    # 月
    mouth = pno[10:12]
    # 日
    day = pno[12:14]
    # 将年存到后面的列
    sh.cell(i+1,max_col+1).value = year
    # 将月存到后面的列
    sh.cell(i+1,max_col+2).value = mouth
    # 将日存到后面的列
    sh.cell(i+1,max_col+3).value = day
  # 保存文件
  wb.save('./create_data/26_提取身份证信息.xlsx')
if __name__ =='__main__':
  get_data()


Python操作Excel模块库文档



https://www.osgeo.cn/openpyxl/index.html 中文

https://openpyxl.readthedocs.io/en/stable/ 英文/可翻译

http://www.python-excel.org/ 汇总网站


Python操作Word基础



在办公自动化的操作,往往可能会存在Word的操作。因为在办公时,对文档的操作是必不可少的。而在Python操作Word时,可以使用一个三方的模块库 Python-docx


安装


pip install python-docx


常用方法与属性

函数名&属性 含义
docx.Document()  创建word文件
doc.add_heading(content,level)  增加word标题
doc.save(path)  保存word文件


代码

from docx import Document
def create_word():
  # 创建word文档
  doc1 = Document()
  # 增加标题
  doc1.add_heading('欢迎使用Python创建Word',0)
  doc1.add_heading('Python操作 增加1级标题',1)
  doc1.add_heading('Python操作 增加2级标题',2)
  # 保存文档
  doc1.save('./create_data/01_创建word文档.docx')
if __name__ == '__main__':
  create_word()


Word写入段落数据



常用方法与属性

函数名&属性  含义
doc.add_paragraph(content,style) 增加word段落
paragraph.add_run(content)  追加word段落内容


# 样式表
from docx.enum.style import WD_STYLE


代码

from docx.enum.style import WD_BUILTIN_STYLE
def create_word():
  from docx import Document
  # 创建一个word文档
  doc1 = Document()
  # 增加段落信息
  doc1.add_paragraph('Python第一阶段','Title')
  # doc1.add_paragraph('Python第一阶段',style = 'Title')
  par1 =doc1.add_paragraph('本阶段是进入“程序员”的门槛,需要学习编程基本的知识。本阶段会从0开始,循序渐进。让小伙伴们学完本阶段,可以掌握:变量、数据类型、控制语句、容器、函数和面向对象等。教程中会穿插一些有趣的案例,寓教于乐,引起大家的兴趣。 ')
  # 给段落后面追加内容
  par1.add_run('“兴趣永远是好的老师,小童只能排第二”。')
  doc1.add_paragraph('本阶段是进入“程序员”的门槛,需要学习编程基本的知识。本阶段会从0开始,循序渐进。让小伙伴们学完本阶段,可以掌握:变量、数据类型、控制语句、容器、函数和面向对象等。教程中会穿插一些有趣的案例,寓教于乐,引起大家的兴趣。 “兴趣永远是好的老师,高淇老师只能排第二”。')
  # 增加列表-无序
  doc1.add_paragraph('哪个不是动物:')
  doc1.add_paragraph('喜洋洋',style='ListBullet')
  doc1.add_paragraph('美羊羊',style='ListBullet')
  doc1.add_paragraph('懒洋洋',style='ListBullet')
  doc1.add_paragraph('苹果',style='ListBullet')
  doc1.add_paragraph('灰太狼',style='ListBullet')
  # 增加列表-有序
  doc1.add_paragraph('今年的学习计划:')
  doc1.add_paragraph('Python',style='ListNumber')
  doc1.add_paragraph('HTML',style='ListNumber')
  doc1.add_paragraph('JS',style='ListNumber')
  doc1.add_paragraph('Flask',style='ListNumber')
  # 增加引用
  doc1.add_paragraph('这个是一个引用内容',style='Intense Quote')
  # 保存word文档
  doc1.save('./create_data/02_增加段落.docx')
if __name__ =='__main__':
  create_word()


Word增加图片



常用方法与属性

函数名&属性 含义
doc.add_picture(path) 增加word图片
pic.height 获取word图片高度
pic.width 获取word图片宽度
doc.sections[0].page_width 获取页面的宽度
doc.sections[0].left_margin 获取页面左边距


代码

def create_word():
  from docx import Document
  # 创建一个文档
  doc1 = Document()
  # 增加图片
  pic = doc1.add_picture('./base_data/backg.jpg')
  # 获取文档的宽度
  page_width = doc1.sections[0].page_width
  # 获取文档的左边距
  page_left_width = doc1.sections[0].left_margin
  print(page_width)
  print(page_left_width)
  # 获取中间内容的宽度
  content_width = page_width-page_left_width*2
  print(content_width)
  # 获取图片应该缩小的比例
  # 如果图片或者页面宽度值太高,有可能程序无法计算,可以考虑同时缩小几倍
  sc =(content_width/100)/(pic.width/100)
  # 修改图片的宽、高
  pic.width = int(pic.width*sc)
  pic.height = int(pic.height*sc)
  # 保存文档
  doc1.save('./create_data/03_增加图片.docx')
if __name__ == '__main__':
  create_word()


Word增加表格



常用方法与属性

函数名&属性 含义
doc.add_table(rows=num,cols=num)  增加word表格
table.add_row().cells  增加一行表格
ell.text 获取/设置单元格
table.rows 获取行数据


代码

def create_table():
  from docx import Document
  # 创建word文档
  doc1 = Document()
  # 增加表格
  table = doc1.add_table(rows=1,cols=3)
  # 设置表格的内容
  cells = table.rows[0].cells
  cells[0].text = '编号'
  cells[1].text = '姓名'
  cells[2].text = '职业'
  data = (
   (1,'吕小布','将军'),
   (2,'诸葛亮','军事'),
   (3,'刘备','主攻'),
 )
  for i,n,w in data:
    # 增加一行数据
    tmp_cell = table.add_row().cells
    '''
   问题1:
   tmp_cell[0] = i
   TypeError: 'tuple' object does not support item assignment 
   有可能是直接给单元格设置内容了!需要给text属性设置内容
   '''
    '''
   问题2:
   for char in text:
   TypeError: 'int' object is not iterable
   给单元格设置值,不能是数字,需要转成str
   '''
    tmp_cell[0].text = str(i)
    tmp_cell[1].text = n
    tmp_cell[2].text = w
  # 保存文档
  doc1.save('./create_data/04_增加表格.docx')
if __name__ =='__main__':
  create_table()
目录
相关文章
|
4月前
|
XML 数据格式 Python
从手动编辑到代码生成:Python 助你高效创建 Word 文档
本文介绍如何用Python实现Word文档自动化生成,结合python-docx、openpyxl和matplotlib库,高效完成报告撰写、数据插入与图表生成,大幅提升办公效率,降低格式错误,实现数据驱动的文档管理。
756 2
|
5月前
|
存储 人工智能 测试技术
如何使用LangChain的Python库结合DeepSeek进行多轮次对话?
本文介绍如何使用LangChain结合DeepSeek实现多轮对话,测开人员可借此自动生成测试用例,提升自动化测试效率。
1044 125
如何使用LangChain的Python库结合DeepSeek进行多轮次对话?
|
5月前
|
监控 数据可视化 数据挖掘
Python Rich库使用指南:打造更美观的命令行应用
Rich库是Python的终端美化利器,支持彩色文本、智能表格、动态进度条和语法高亮,大幅提升命令行应用的可视化效果与用户体验。
456 0
|
4月前
|
数据可视化 关系型数据库 MySQL
【可视化大屏】全流程讲解用python的pyecharts库实现拖拽可视化大屏的背后原理,简单粗暴!
本文详解基于Python的电影TOP250数据可视化大屏开发全流程,涵盖爬虫、数据存储、分析及可视化。使用requests+BeautifulSoup爬取数据,pandas存入MySQL,pyecharts实现柱状图、饼图、词云图、散点图等多种图表,并通过Page组件拖拽布局组合成大屏,支持多种主题切换,附完整源码与视频讲解。
421 4
【可视化大屏】全流程讲解用python的pyecharts库实现拖拽可视化大屏的背后原理,简单粗暴!
|
4月前
|
传感器 运维 前端开发
Python离群值检测实战:使用distfit库实现基于分布拟合的异常检测
本文解析异常(anomaly)与新颖性(novelty)检测的本质差异,结合distfit库演示基于概率密度拟合的单变量无监督异常检测方法,涵盖全局、上下文与集体离群值识别,助力构建高可解释性模型。
442 10
Python离群值检测实战:使用distfit库实现基于分布拟合的异常检测
|
6月前
|
运维 Linux 开发者
Linux系统中使用Python的ping3库进行网络连通性测试
以上步骤展示了如何利用 Python 的 `ping3` 库来检测网络连通性,并且提供了基本错误处理方法以确保程序能够优雅地处理各种意外情形。通过简洁明快、易读易懂、实操性强等特点使得该方法非常适合开发者或系统管理员快速集成至自动化工具链之内进行日常运维任务之需求满足。
419 18
|
6月前
|
机器学习/深度学习 API 异构计算
JAX快速上手:从NumPy到GPU加速的Python高性能计算库入门教程
JAX是Google开发的高性能数值计算库,旨在解决NumPy在现代计算需求下的局限性。它不仅兼容NumPy的API,还引入了自动微分、GPU/TPU加速和即时编译(JIT)等关键功能,显著提升了计算效率。JAX适用于机器学习、科学模拟等需要大规模计算和梯度优化的场景,为Python在高性能计算领域开辟了新路径。
591 0
JAX快速上手:从NumPy到GPU加速的Python高性能计算库入门教程
|
6月前
|
数据采集 存储 Web App开发
Python爬虫库性能与选型实战指南:从需求到落地的全链路解析
本文深入解析Python爬虫库的性能与选型策略,涵盖需求分析、技术评估与实战案例,助你构建高效稳定的数据采集系统。
534 0
|
6月前
|
存储 监控 安全
Python剪贴板监控实战:clipboard-monitor库的深度解析与扩展应用
本文介绍了基于Python的剪贴板监控技术,结合clipboard-monitor库实现高效、安全的数据追踪。内容涵盖技术选型、核心功能开发、性能优化及实战应用,适用于安全审计、自动化办公等场景,助力提升数据管理效率与安全性。
253 0
|
6月前
|
监控 Linux 数据安全/隐私保护
Python实现Word转PDF全攻略:从入门到实战
在数字化办公中,Python实现Word转PDF自动化,可大幅提升处理效率,解决格式兼容问题。本文详解五种主流方案,包括跨平台的docx2pdf、Windows原生的pywin32、服务器部署首选的LibreOffice命令行、企业级的Aspose.Words,以及轻量级的python-docx+pdfkit组合。每种方案均提供核心代码与适用场景,并涵盖中文字体处理、表格优化、批量进度监控等实用技巧,助力高效办公自动化。
1572 0

推荐镜像

更多