使用Python将Excel数据导入Word并设置字体样式(成功)

在日常办公和数据处理中,我们经常需要将Excel中的数据导入到Word文档中。手动完成这个过程可能既费时又容易出错。本文将介绍如何使用Python自动化这一任务,同时根据数据的不同设置不同的字体样式和大小。

所需工具

  • Python:一种广泛使用的高级编程语言。
  • openpyxl:一个用于读写Excel 2010 xlsx/xlsm/xltx/xltm文件的Python库。
  • python-docx:一个用于创建和更新Microsoft Word (.docx) 文件的Python库。

安装依赖库

首先,确保安装了openpyxlpython-docx库。如果还没有安装,可以通过以下命令进行安装:

pip install openpyxl python-docx

代码示例

以下是一个简单的代码示例,它读取Excel文件中的数据,并将其导入到一个新的Word文档中。我们还会根据列的不同设置不同的字体样式和大小。

python 复制代码
from docx import Document
from docx.shared import Pt
from docx.enum.text import WD_PARAGRAPH_ALIGNMENT
import openpyxl

# 加载Excel工作簿和活动工作表
excel_path = r'C:\path\to\your\excel.xlsx'
workbook = openpyxl.load_workbook(excel_path)
sheet = workbook.active

# 创建一个新的Word文档
doc = Document()

# 遍历Excel工作表的每一行,从第2行开始
for row in sheet.iter_rows(min_row=2, values_only=True):
    for i, content in enumerate(row[:4], start=1):
        paragraph = doc.add_paragraph()
        run = paragraph.add_run(str(content))

        # 设置字体样式和大小
        if i in [1, 2]:  # 第1和第2列
            run.font.size = Pt(14)
            run.font.bold = True
        elif i in [3, 4]:  # 第3和第4列
            run.font.size = Pt(12)
            run.font.bold = False

        run.font.name = '宋体'
        paragraph.alignment = WD_PARAGRAPH_ALIGNMENT.LEFT

    # 在各行之间添加一个空行作为分隔
    doc.add_paragraph()

# 保存Word文档
doc.save(r'C:\path\to\your\output.docx')

结论

使用Python自动将Excel数据导入Word文档不仅可以节省大量手动操作的时间,还可以减少因手动操作导致的错误。通过上述方法,我们可以根据需要轻松地自定义字体样式和大小,使得生成的文档既美观又专业。

相关推荐
好家伙VCC1 天前
### WebRTC技术:实时通信的革新与实现####webRTC(Web Real-TimeComm
java·前端·python·webrtc
前端玖耀里1 天前
如何使用python的boto库和SES发送电子邮件?
python
serve the people1 天前
python环境搭建 (十二) pydantic和pydantic-settings类型验证与解析
java·网络·python
小天源1 天前
Error 1053 Error 1067 服务“启动后立即停止” Java / Python 程序无法后台运行 windows nssm注册器下载与报错处理
开发语言·windows·python·nssm·error 1053·error 1067
喵手1 天前
Python爬虫实战:HTTP缓存系统深度实战 — ETag、Last-Modified与requests-cache完全指南(附SQLite持久化存储)!
爬虫·python·爬虫实战·http缓存·etag·零基础python爬虫教学·requests-cache
喵手1 天前
Python爬虫实战:容器化与定时调度实战 - Docker + Cron + 日志轮转 + 失败重试完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·容器化·零基础python爬虫教学·csv导出·定时调度
2601_949146531 天前
Python语音通知接口接入教程:开发者快速集成AI语音API的脚本实现
人工智能·python·语音识别
寻梦csdn1 天前
pycharm+miniconda兼容问题
ide·python·pycharm·conda
Java面试题总结1 天前
基于 Java 的 PDF 文本水印实现方案(iText7 示例)
java·python·pdf
不懒不懒1 天前
【决策树算法实战指南:从原理到Python实现】
python·决策树·id3·c4.5·catr