背景需求
学期总结开始写各种总结
data:image/s3,"s3://crabby-images/f7e61/f7e61d61fb1802ae59ab178b48edad59cb8f466f" alt=""
同事请我代写
data:image/s3,"s3://crabby-images/88b8a/88b8af7bc3ebef26ded374010c7f8f3c4aafe674" alt=""
我手里写5个老师要写。就想试试能不能用"星火讯飞写稿子"+Python(excle \word)批量生成)
一、AI生成读后感
星火讯飞写出来的读后感内容相同,所以要用不同的关键词
1、不同岗位:假如您是一位班主任、假如您是一位幼儿园管理者、假如您是一位保育工作者)
2、同样都是幼儿老师,就在"于漪老师事迹"后面写,围绕"幼儿发展优先分析""谈谈师幼互动""结合理解发现支持幼儿"等不同的元素写
3、字数是1000字。但总体感觉很少,下次用2000字,但可能也就1000字
篇幅有限这里不介绍如何获取读后感文字,只是把文字都贴入EXCLE的content内
data:image/s3,"s3://crabby-images/f457e/f457e4f7d0431600e2beb477ebf3c7664c5db4aa" alt=""
data:image/s3,"s3://crabby-images/05125/05125f80de2c8e1ce083cb1e105108ee6650ce5e" alt=""
从AI复制的读后感,要选中单元格,点击顶部的输入框,把文字全部贴入,这样文字都在一个单元格里,才能一次性写入(重要)
data:image/s3,"s3://crabby-images/9fc33/9fc3301e5f5e5641b9e3d74646a499590dfe4296" alt=""
此外每个单元格第一行要空(手动换行符)
data:image/s3,"s3://crabby-images/6f3b2/6f3b2475632fdefe2428044a12f88a7e54430f56" alt=""
data:image/s3,"s3://crabby-images/33ef0/33ef051ecde80de94e38f3c7148b4a813e8d41da" alt=""
二、删除单元格里的手动换行符
测试后发现还是需要再EXCEL里删除手动换行符(空行),而不是在Python里修改
EXCEL用VBA宏进行换行符的替换
data:image/s3,"s3://crabby-images/2b2fc/2b2fcf9c6489c7025766e01f050cc7e99364cd0b" alt=""
第1步:在EXCEL界面上ALT+F11
data:image/s3,"s3://crabby-images/ec0fa/ec0fabb3695e3fc9c168778d56d561688de85619" alt=""
第2步:VBA窗体 插入-模块
data:image/s3,"s3://crabby-images/c6b3f/c6b3fcaaf9eca383d2db7271f7f1cb9c6a02e8f9" alt=""
第3步:黏贴代码
data:image/s3,"s3://crabby-images/b7491/b74918c5694eea8b4e9ecc8876cda1056c968cb4" alt=""
VBA代码
Sub 删除单元格内空行()
Dim cell As Range
For Each cell In Selection
If InStr(cell.Value, Chr(10)) > 0 Then
cell.Value = Replace(cell.Value, Chr(10), "123")
End If
Next cell
End Sub
第4步:两次关闭
data:image/s3,"s3://crabby-images/d7a4d/d7a4d87cd7b5ed594c702f78a7e4280b6ad74c99" alt=""
第5步:选中读后感(有换行符空行)
data:image/s3,"s3://crabby-images/0d3ef/0d3efcc680df35b3e2ed911308ef7df1ce3496c4" alt=""
第6步:开发工具-宏-选中刚才代码-运行data:image/s3,"s3://crabby-images/58fef/58fef7f49f14183ae4828a80dbbaa2b9d1b96ca6" alt=""
第7步:所有换行符空行都被改成123(如果有两个123,说明这里面有两个连续的换行符也就是一个是空行)
data:image/s3,"s3://crabby-images/7c998/7c9981e32ea157633820ae9846a90b5fe1e51be8" alt=""
保存EXCEL关闭
data:image/s3,"s3://crabby-images/fc35e/fc35e1c99a1b9a7131434699c82e9f09b854b5f7" alt=""
data:image/s3,"s3://crabby-images/3cee2/3cee22e9554d16a90adf3628fa8a4d182ea72ae4" alt=""
三、制作WORD模版
本次需要制作两个内容相同,标题不同的读后感
data:image/s3,"s3://crabby-images/b5f60/b5f60f6fc4aa24fafe21bab3a7787831a83d56fd" alt=""
(一)工会学后感
原始样式
data:image/s3,"s3://crabby-images/90de1/90de13113dcf5e5c3a9d280e14c57f8a533254f4" alt=""
修改后样式
data:image/s3,"s3://crabby-images/046cd/046cd425ed069e9a5ad5f89f174c4648cf4a64c6" alt=""
(二)校本研修小结
原始样式
data:image/s3,"s3://crabby-images/207c4/207c49e332aa0c801136e43d6ee6a9cd4eaac951" alt=""
修改后样式
data:image/s3,"s3://crabby-images/ffd72/ffd72c0dc3c62678f306f319ba2c1732b6c78bcf" alt=""
特别说明:
读后感content部分的字体是宋体小四,但是我每次导入后,会变成宋体小五
data:image/s3,"s3://crabby-images/eb279/eb2799c833e46bf7bbf7ce3385aff6f4db61dc1e" alt=""
原来是模版里预设的正文样式字体就是宋体小五。所以我把正文样式字体改成小四,就解决了问题。
data:image/s3,"s3://crabby-images/ee7bd/ee7bd45a01e94512d2238131864e0073071690f0" alt=""
四、EXCEL制作
data:image/s3,"s3://crabby-images/56da3/56da3b9d504fb693608c7347797956492c95a7ba" alt=""
data:image/s3,"s3://crabby-images/e0f9b/e0f9b109cc0346ddbd7c5671e4cc17f0ab5b1ba7" alt=""
五、代码展示
python
from docxtpl import DocxTemplate
import pandas as pd
import os,time
from docx import Document
from docx.enum.text import WD_PARAGRAPH_ALIGNMENT
from docx.shared import Pt
import win32com.client as win32
from docxtpl import DocxTemplate
import pandas as pd
import os
from docx import Document
from docx.enum.text import WD_PARAGRAPH_ALIGNMENT
from docx.shared import Pt
import win32com.client as win32
zpath = r'C:\Users\jg2yXRZ\OneDrive\桌面\校本研修'
print('-------------1、生成WORD-------------')
n=['工会学后感','校本研修小结']
for x in n:
template_path = os.path.join(zpath, f'{x}.docx')
output_path = os.path.join(zpath, '整理')
os.makedirs(output_path, exist_ok=True)
tpl = DocxTemplate(template_path)
autho = pd.read_excel(os.path.join(zpath, 'autho.xlsx'))
num = autho["num"].astype(str).str.rstrip() #
name = autho['name'].str.rstrip() #
title = autho['title'].str.rstrip()
content = autho['content'].str.rstrip()
# print
num1 = autho.shape[0]
for i in range(num1):
context = {
"num": num[i],
"name": name[i],
"title": title[i],
"content": content[i],
}
tpl = DocxTemplate(template_path)
tpl.render(context)
output_filename = f"{int(num[i]):02} {name[i]} {x}.docx"
output_file_path = os.path.join(output_path, output_filename)
# try:
tpl.save(output_file_path)
print('-------------2、123替换硬回车和缩进四字符-------------')
def replace_text_in_docx(docx_path, old_text, new_text):
doc = Document(docx_path)
for para in doc.paragraphs:
if old_text in para.text:
para.text = para.text.replace(old_text, new_text)
doc.save(docx_path)
for root, dirs, files in os.walk(output_path):
for file in files:
if file.endswith(".docx"):
file_path = os.path.join(root, file)
replace_text_in_docx(file_path, "123123", "\n ")
replace_text_in_docx(file_path, "123", "\n ")
print('-------------3、删除第一个软回车-------------')
data:image/s3,"s3://crabby-images/af024/af02449ba6d2320cca08b03944742e70cd401a19" alt=""
(一)获取有123的文档
data:image/s3,"s3://crabby-images/0bd01/0bd0124c0aa39698d5d3435b640df64871021943" alt=""
data:image/s3,"s3://crabby-images/833b1/833b1ec8f0f62f97234991d6c26d5a7d18186f7e" alt=""
(二)123变成软回车(替换原来位置)
(三)删除第一个软回车
本文样式是前面5行要的,第6行就是第一段内容,因此这里多的一个软回车需要删除
data:image/s3,"s3://crabby-images/3937e/3937e342a25b64e419f82db3991a6c3cb10f3322" alt=""