背景需求:
好不容易找到一款“红豆空心黑体”,可以让孩子们对自己的名字进行空心涂色,
【教学类-35-22】正式版 20240129名字字卡3.0(15CM正方形手工纸、先男后女,页眉是黑体包含全名,名字是红豆空心黑体)-CSDN博客文章浏览阅读661次,点赞13次,收藏16次。【教学类-35-22】正式版 20240129名字字卡3.0(15CM正方形手工纸、先男后女,页眉是黑体包含全名,名字是红豆空心黑体)
https://blog.csdn.net/reasonsummer/article/details/135917732
但是发现“玥”“璟”这两个字没有变成空心,进一步搜索查看那些字不能变成空心
【教学类-35-23】20240130“红豆空心黑体”不能显示的汉字-CSDN博客文章浏览阅读444次,点赞17次,收藏10次。【教学类-35-23】20240130“红豆空心黑体”不能显示的汉字
https://blog.csdn.net/reasonsummer/article/details/135939114
初步获得22个不能变成空心的名字。
![f3da7d7eb0074f4b859f15bb4d792084.png](https://i-blog.csdnimg.cn/blog_migrate/71ca4c2559c16508c9bf80753518614e.png)
我希望在“红豆空心黑体”遇到这些名字时,自动换成“文艺空心黑体”。
素材准备:
![0b739b95b2994dfe988f7fb75431f643.png](https://i-blog.csdnimg.cn/blog_migrate/13fd9b08d7e17096b7983f64a820ac61.png)
WORD模板
![2240c961c7f949458dd8a39311151e44.png](https://i-blog.csdnimg.cn/blog_migrate/88d3934fbf62f8dca3c9896ea0d321a8.png)
![b15ff24dca0d4f678bfa592f521c607d.png](https://i-blog.csdnimg.cn/blog_migrate/ebe69b7bc7b9b97ea37751207d652b00.png)
![27cb17fd16f94c57a6fe2d8d1dd6325d.png](https://i-blog.csdnimg.cn/blog_migrate/308fc35ab40dcfeb51df43e066568e46.png)
EXCEL表单——红色是“红豆空心黑体”不能显示空心的字体,需要改成“文艺空心黑体”
![48b69a0e757f4d23b4a281065ebae54c.png](https://i-blog.csdnimg.cn/blog_migrate/7b53e50052cc8685ecefe000edb4f30e.png)
代码展示:
'''
20240202中4班描字帖正方形字卡3.0 页眉是黑体 名字用红豆空心黑体+文艺空心黑体 先男后女
作者:阿夏
时间:2024年2月2日
'''
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
# hs=int(input('一行2个,需要几行(1行,还有6行是表格)\n'))
print('----------第1步:新建一个临时文件夹------------')
# 新建一个”装N份word和PDF“的临时文件夹
imagePath1=r'C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\零时Word'
if not os.path.exists(imagePath1): # 判断存放图片的文件夹是否存在
os.makedirs(imagePath1) # 若图片文件夹不存在就创建
gz=23
wb= xlrd.open_workbook(r"C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\20240117中4班学号描字帖\学生名单.xlsx") #打开文件并返回一个工作蒲对象。open_workbook可以点进去看看函数里面的参数的含义之类的,很详细,英语不好的可以百度翻译,翻译出来的结果差不多。
sheet=wb.sheet_by_index(0) #通过索引的方式获取到某一个sheet,现在是获取的第一个sheet页,也可以通过sheet的名称进行获取,sheet_by_name('sheet名称')
col1=sheet.col_values(0)# 学号
col2=sheet.col_values(1)# 名字
col3=sheet.col_values(2)# 班级
col4=sheet.col_values(3)# 性别
num=len(col1)-1 # 第一列去掉第一行
numberall=[]
numberall_boy=[]
numberall_girl=[]
# 生成 基本组:“中4 1号 第1个名字“
for num in range(1,len(col1)):
for x in range(len(col2[num])): # 如果名字长度等于3,就写3个名字 如果名字长度2,就写2个名字
if col4[num]=='男':
name00=str(col3[num]) +' 学号:'+str(int(col1[num])) +'号'+' '+col2[num]+' 第'+str(x+1)+'名字' #中4 学号1号 张三第1字
name01=str(col2[num][x])
numberall_boy.append(name00)
numberall_boy.append(name01)
if col4[num]=='女':
name00=str(col3[num]) +' 学号:'+str(int(col1[num])) +'号'+' '+col2[num]+' 第'+str(x+1)+'名字' #中4 学号1号 张三第1字
name01=str(col2[num][x])
numberall_girl.append(name00)
numberall_girl.append(name01)
print(len(numberall_boy))
print(len(numberall_girl))
numberall=numberall_boy+numberall_girl
print(numberall)
print(int(len(numberall)/2))
# 需要打印172/2=86张
# 分成2组,第一组是字序。是黑体28,第二组是名字,是黑体288超大
gz=2
list1=[]
list2=[]
list=[]
for fk in range(int(len(numberall)/gz)):
list1.append(numberall[fk*gz])
list2.append(numberall[fk*gz+1])
list.append(list1)
list.append(list2)
print(list)
print(len(list))
# 2
# 每页只有2个坐标
bg=[]
bg1=[]
bg2=[]
bgall=['0000','0100']
for b in range(len(list1)):
bg1.append(bgall[0])
bg2.append(bgall[1])
bg.append(bg1)
bg.append(bg2)
print(bg)
# 字号
size=[]
size1=[]
size2=[]
sizeall=['28','377']
for si in range(len(list1)):
size1.append(sizeall[0])
size2.append(sizeall[1])
size.append(size1)
size.append(size2)
print(size)
# 字体
typeface=[]
typefacetwo=[]
typeface1=[]
typeface2=[]
typefaceall=['黑体','红豆空心黑体']
typefaceall1='文艺空心黑体'
# '红豆空心黑体'
for ty in range(len(list1)):
typeface1.append(typefaceall[0])
typeface2.append(typefaceall[1])
typeface.append(typeface1)
typeface.append(typeface2)
print(typeface)
w=['玥','锜','玗','琇','祎','翾','淏','爀','浵','旸','晞','旻','珵','瑄','璟','晅','橒','喆','珺','珣','妘','扞']
for t in range(len(list1)): # 86 # 2
# for b in range(2):
doc = docx.Document(r"C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\20240117中4班学号描字帖\中4班描字帖正方形.docx")
table = doc.tables[0]
# print(p)
for n in range(len(list)):
# 字体大小
sss=int(size[n][t])
pp=int(bg[n][t][0:2]) # 提取表格bg里面每个元素的第0个数字==单元格X坐标 t=索引数字
qq=int(bg[n][t][2:4])
k=str(list[n][t])
print(pp,qq,k)
run=table.cell(pp,qq).paragraphs[0].add_run(k) # 在单元格0,0(第1行第1列)输入第0个名字
# 如果名字等于某些字,就写入'文艺空心黑体'
# if k =='玥' or k =='璟': # 如果名字等于某些字,就写入'文艺空心黑体'
if k in w: # 如果有相等的汉字 ['玥','锜','玗','琇','祎','翾','淏','爀','浵','旸','晞','旻','珵','瑄','璟','晅','橒','喆','珺','珣','妘','扞']
run.font.name =typefaceall1 #'文艺空心黑体'
# print(typefaceall1)
run.font.size = Pt(int(sizeall[1])) #377
run.bold=True
run.font.color.rgb = RGBColor(150,150,150) #设置颜色10%黑色=深灰
r = run._element
r.rPr.rFonts.set(qn('w:eastAsia'), typefaceall1) #'文艺空心黑体'
table.cell(pp,qq).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.CENTER #居中
# 如果不等于这些汉字,就正常输入页眉黑体,名字红豆空心黑体
else:
run.font.name =typeface[n][t] #黑体 或 红豆空心黑体
# print(typefaceall1)
run.font.size = Pt(sss) #输入字体大小28 和377
run.bold=True
run.font.color.rgb = RGBColor(150,150,150) #设置颜色10%黑色=深灰
r = run._element
r.rPr.rFonts.set(qn('w:eastAsia'), typeface[n][t])# 黑体 或 红豆空心黑体
table.cell(pp,qq).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.CENTER #居中
doc.save(r'C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\零时Word\{}.docx'.format('%02d'%t))#保存为XX学号的零时word
time.sleep(2)
from docx2pdf import convert
# docx 文件另存为PDF文件
inputFile = r"C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\零时Word\{}.docx".format('%02d'%t)# 要转换的文件:已存在
outputFile = r"C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\零时Word\{}.pdf".format('%02d'%t) # 要生成的文件:不存在
# 先创建 不存在的 文件
f1 = open(outputFile,'w')
f1.close()
# 再转换往PDF中写入内容
convert(inputFile, outputFile)
time.sleep(2)
from docx2pdf import convert
print('----------第4步:把都有PDF合并为一个打印用PDF------------')
import os
from PyPDF2 import PdfMerger
target_path = 'C:/Users/jg2yXRZ/OneDrive/桌面/描字帖/零时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/桌面/描字帖/(打印合集)中4班描字卡片 男蓝色{}张女粉色{}张 {}+{}({}份).pdf".format(int(len(numberall_boy)/2),int(len(numberall_girl)/2),typefaceall[1],typefaceall1,num))
file_merger.close()
# doc.Close()
# # print('----------第5步:删除临时文件夹------------')
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/描字帖/零时Word') #递归删除文件夹,即:删除非空文件夹`
终端展示:
![ca812eab546442e9af41c6f91ddb2129.png](https://i-blog.csdnimg.cn/blog_migrate/3c53d1a8a533f4e53a76a6d56ae823c2.png)
![1d5c19f7e5474fcc94f4079c3c4b2be6.png](https://i-blog.csdnimg.cn/blog_migrate/adb2c39894fa898e3fe39661aafc8a70.png)
重点说明:
![3a18a07df098468da13c6825250675e8.png](https://i-blog.csdnimg.cn/blog_migrate/254d3f237df94ebccadede6f1acb60da.png)
![98486e4067ab445ab88006b5f4f1a3c4.png](https://i-blog.csdnimg.cn/blog_migrate/683d1fd66292b99826bd92a5e2d3a61e.png)
作品展示:
![4aa0f547e3ad460cbc07205944004e37.png](https://i-blog.csdnimg.cn/blog_migrate/5a0bf1bb7b8a404bf8a915dd8b20c4c7.png)
![48b69a0e757f4d23b4a281065ebae54c.png](https://i-blog.csdnimg.cn/blog_migrate/7b53e50052cc8685ecefe000edb4f30e.png)
先男2人:李四璟、王旻五
![2934f97d7ca44c09a33c979b2115ca5e.png](https://i-blog.csdnimg.cn/blog_migrate/065e8cf020797145daf974a75fe185ef.png)
后女2人:张三玥、赵喆六
![d212bbc3a5ce4f598f0813eac0e0dbf0.png](https://i-blog.csdnimg.cn/blog_migrate/341f8ab019cb5ecbae886fa1b7c747bb.png)
虽然“红豆空心黑体”和“文艺空心黑体”的外形,边框粗细不同。但是题目都是空心的,满足了涂色的需求。
![25ce5469f6c24f2999c97954cf6cf774.png](https://i-blog.csdnimg.cn/blog_migrate/86b665df12c392547e3695c59e87fb1d.png)
如果都是红豆空心黑体,部分无法识别的字(22个字)会自动变成黑色实心的样式,无法涂色(类似于微软雅黑)
![9f3a1967268c4fbbb3fe2ad4a7a520ee.png](https://i-blog.csdnimg.cn/blog_migrate/f9a0e19188fb9ec7263b87cbfeb21e27.png)
感悟;
用这个方法,排除某些字体中无法显示的汉字,努力符合自己的教学需求