作品展示
前四行是一个数字的描写
后四行是合并的年份4个数字
背景需求:
大4班17号孩子练习数字书写,上一次是“17”号和大“4”,第3份就是年份
【教学类-35-05】17号的学号字帖(A4竖版1份)-CSDN博客文章浏览阅读440次,点赞6次,收藏7次。【教学类-35-05】17号的学号字帖(A4竖版1份)https://blog.csdn.net/reasonsummer/article/details/134888067
【教学类-35-07】17号的字帖(二)班级字帖“大4”(A4竖版1份)-CSDN博客文章浏览阅读142次,点赞2次,收藏4次。【教学类-35-07】17号的字帖(二)班级字帖“大4”(A4竖版1份)https://blog.csdn.net/reasonsummer/article/details/135253520WORD模板:参数见上面的链接(微调:下面四行的格子两两合并)
代码展示:
'''
作者:阿夏
时间:20231227
名称:大4班17号的描字帖——年份 练习 2023
'''
import xlwt
import xlrd
import os
import random
from win32com.client import constants,gencache
from win32com.client.gencache import EnsureDispatch
from win32com.client import constants # 导入枚举常数模块
import os,time
import docx
from docx import Document
from docx.shared import Pt
from docx.shared import RGBColor
from docx.enum.text import WD_PARAGRAPH_ALIGNMENT
from docx.oxml.ns import qn
from docxtpl import DocxTemplate
import pandas as pd
from docx2pdf import convert
from docx.shared import RGBColor
# 需要几行已有文字
nn=8
# int(input('一共几行(8行、其中4行是两个数字,4行是1组数字)\n'))
mm=6
# int(input('一共几列(6列)\n'))
kk=int(input('需要空几行(让幼儿自由书写用(最少0行(全是描红字),最多4行(整页空白自己写)\n'))
# s=int(input('请输入学号(17)\n'))
s='2023'
# 分开的学号
w=int((nn/2-kk)*mm) # 8行的一半=4行,4行中的3行有数字,1行无数字
kg='' # 空格
# 有学号的部分
list1=[]
for s1 in range(len(s)): # 2023=4个数字
for s2 in range(mm*2): #2循环12次,写1一行
list1.append(s[s1])
# 空行部分让幼儿自己填写
for b1 in range(kk*mm*2):
list1.append(kg)
print(list1)
print(len(list1))
# 48
# 有学号的部分
list2=[]
for a2 in range(0,int((mm/2)*(nn/2))): # 只要3*4=12个2023
# r='大'
list2.append(s)
# 空行部分让幼儿自己填写
for b2 in range(kk*mm):
list2.append(kg)
print(list2)
print(len(list2))
# 24
# 合并的学号
list=list1+list2
print(list)
print(len(list))
# # 48+24=72
# 制作所有单元格的数字
# 前4行的坐标
bg1=[]
for x1 in range(1,int(nn/2)+1): # 8/2=4行 第一行是标题,所以从索引1(第2行开始)
for y1 in range(0,mm*2): #6列*2 数字拆开的2份,所以是12格子
c1='{}{}'.format('%02d'%x1,'%02d'%y1)
bg1.append(c1)
print(bg1)
print(len(bg1))
# 后4行的坐标
bg2=[]
for x2 in range(1+int(nn/2),nn+1): # 从第5行开始,到第8行+1
for y2 in range(0,mm*2,4): #6列*4 0-12 之间,所有的0,4,8坐标
c2='{}{}'.format('%02d'%x2,'%02d'%y2)
bg2.append(c2)
print(bg2)
print(len(bg2))
# 一页所有的坐标
bg=bg1+bg2
print(bg)
print(len(bg))
# 标题坐标
# bt=['我是中國人,你好,他她它']
bt='年份:{} {} {} {}'.format(s,s[0],s[1],s[3])
zb='0000'
# 插入标题的坐标和内容
bg.insert(0,zb)
list.insert(0,bt)
print(len(bg))
print(len(list))
print('----------第1步:新建一个临时文件夹------------')
# 新建一个”装N份word和PDF“的文件夹
dir_name=r'C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\17号的数字练字帖\零时Word'
if not os.path.exists(dir_name):
os.mkdir(dir_name)
# doc= docx.Document(r"C:\Users\jg2yXRZ\OneDrive\桌面\描字贴\打印合集描字贴.docx")# 新建Word
for n in range(1): # 一共多少份
doc = docx.Document(r"C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\17号的数字练字帖\17号的日期字帖.docx")
table = doc.tables[0]
for p in range(0,len(bg)): # 一共有9个表格
# pp=int(bg[p][0:2]) # 提取表格bg里面每个元素的第0个数字==单元格X坐标 t=索引数字
# qq=int(bg[p][2:4])
# # f=font[t] # 字体格式
# k=list[n][p] # 从4名字里提取名字\
pp=int(bg[p][0:2]) # 提取表格bg里面每个元素的第0个数字==单元格X坐标 t=索引数字
qq=int(bg[p][2:4])
# f=font[t] # 字体格式
k=list[p] # 只有一个,所以不要n
print(pp,qq,k)
run=table.cell(pp,qq).paragraphs[0].add_run(k) # 在单元格0,0(第1行第1列)输入第0个名字
# run.font.name = 'AR StdKaiGDLB5 Md' #文鼎虚线
run.font.name = '黑体' #输入时不同字体
run.font.size = Pt(61) #输入字体大小80或68号
run.Bold=True
run.font.color.rgb = RGBColor(200,200,200) #设置颜色10%黑色=深灰
r = run._element
r.rPr.rFonts.set(qn('w:eastAsia'), '黑体' )#将输入语句中的中文部分字体变为华文行楷
table.cell(pp,qq).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.CENTER #居中
doc.save(r'C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\17号的数字练字帖\零时Word\{}.docx'.format('%02d'%n))#保存为XX学号的零时word
time.sleep(2)
from docx2pdf import convert
# docx 文件另存为PDF文件
inputFile = r"C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\17号的数字练字帖\零时Word\{}.docx".format('%02d'%n)# 要转换的文件:已存在
outputFile = r"C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\17号的数字练字帖\零时Word\{}.pdf".format('%02d'%n) # 要生成的文件:不存在
# 先创建 不存在的 文件
f1 = open(outputFile,'w')
f1.close()
# 再转换往PDF中写入内容
convert(inputFile, outputFile)
from docx2pdf import convert
print('----------第4步:把都有PDF合并为一个打印用PDF------------')
import os
from PyPDF2 import PdfMerger
target_path = 'C:/Users/jg2yXRZ/OneDrive/桌面/描字帖/17号的数字练字帖/零时Word'
pdf_lst = [f for f in os.listdir(target_path) if f.endswith('.pdf')]
pdf_lst = [os.path.join(target_path, filename) for filename in pdf_lst]
pdf_lst.sort()
file_merger = PdfMerger()
for pdf in pdf_lst:
print(pdf)
file_merger.append(pdf)
# file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/描字帖/(打印合集)大班A整页描字帖2乘5加表格-4名字-({}人).pdf".format(num))
file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/描字帖/17号的数字练字帖/(打印合集)17号的2023字帖({}份).pdf".format(int(n+1)))
file_merger.close()
# doc.Close()
# # print('----------第5步:删除临时文件夹------------')
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/描字帖/17号的数字练字帖/零时Word') #递归删除文件夹,即:删除非空文件夹`
终端输入:
0=全部是描红字
作品展示:
2023有3个数字 0 2 3,标题栏上多写了203,准备打印后,用记号笔画出笔画顺序。提示幼儿正确的书写方法
前