作品展示
背景需求:
以下代码已经制作出页眉黑体、名字是空心黑体的样式:
【教学类-35-21】20240129名字字卡2.0(15CM正方形手工纸、页眉是黑体,名字是红豆空心黑体)-CSDN博客文章浏览阅读498次,点赞5次,收藏6次。【教学类-35-21】20240129名字字卡2.0(15CM正方形手工纸、页眉是黑体,名字是红豆空心黑体)https://blog.csdn.net/reasonsummer/article/details/135909194?csdn_share_tail=%7B%22type%22%3A%22blog%22%2C%22rType%22%3A%22article%22%2C%22rId%22%3A%22135909194%22%2C%22source%22%3A%22reasonsummer%22%7D
存在问题
1、按学号的顺序生成,但我希望全部男孩信息在前面,女孩信息在后i面
需求:目前我希望男孩的名字用浅蓝色手工纸打印,女孩的名字用粉红色手工纸打印,所以要提取幼儿性别,将同性别孩子的名字放在一起。再做一个性别合并版但我希望全部男孩信息在前面,女孩信息在后面
2、页眉只有学号,但目前我不熟悉中4班幼儿的全名和学号,只有一个大字无法背出幼儿全名,
需求:页眉里面包含 学号 全名 ,第几个字
代码修改:
1、增加第4列信息(性别)
2、分别提取男女的信息,写入不同的列表
页眉里面加入全名
3、保存文件名修改——需要几张蓝色纸(男名)需要几张粉色纸(女名)
代码展示:
'''
20240129中4班描字帖正方形字卡3.0 页眉是黑体 名字用红豆空心黑体,先男后女
作者:阿夏
时间:2024年1月29日'''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=23wb= 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=[]
typeface1=[]
typeface2=[]
typefaceall=['黑体','红豆空心黑体']
for ty in range(len(list1)):typeface1.append(typefaceall[0])typeface2.append(typefaceall[1])
typeface.append(typeface1)
typeface.append(typeface2)
print(typeface)
# '华文彩云''华光彩云_CNKI'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)): pp=int(bg[n][t][0:2]) # 提取表格bg里面每个元素的第0个数字==单元格X坐标 t=索引数字qq=int(bg[n][t][2:4]) k=list[n][t]print(pp,qq,k)# 字体大小sss=int(size[n][t])run=table.cell(pp,qq).paragraphs[0].add_run(str(k)) # 在单元格0,0(第1行第1列)输入第0个名字run.font.name =typeface[n][t] #输入时不字体run.font.size = Pt(sss) #输入字体大小80或68号run.bold=Truerun.font.color.rgb = RGBColor(150,150,150) #设置颜色10%黑色=深灰r = run._elementr.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(1)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(1)from docx2pdf import convertprint('----------第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],num))file_merger.close()# doc.Close()# # print('----------第5步:删除临时文件夹------------')
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/描字帖/零时Word') #递归删除文件夹,即:删除非空文件夹`