【教学类-35-23】正式版 20241212名字字卡4.0(15CM正方形手工纸、男女分开打印,页眉是黑体包含全名,名字是红豆空心黑体)

背景需求:

最近重新把各种名字贴的代码进行整理。

以下是正方手工纸大小的名字字卡

【教学类-35-22】正式版 20240129名字字卡3.0(15CM正方形手工纸、先男后女,页眉是黑体包含全名,名字是红豆空心黑体)-CSDN博客文章浏览阅读756次,点赞13次,收藏16次。【教学类-35-22】正式版 20240129名字字卡3.0(15CM正方形手工纸、先男后女,页眉是黑体包含全名,名字是红豆空心黑体)https://blog.csdn.net/reasonsummer/article/details/135917732

本次代码修改范围:

1、原来代码只考虑标题栏是2个名字、3个名字。正好一行。

中4 学号:XX号 XXX 第X个名字(19字符)28磅

如果标题栏是4个名字,改如何调整字符数量,正好一行。修改后

中4班 XX号 XXXX 第X个名字(18字符,28磅)

2、原来代码是一个PDF,先男后女,我希望做成两个PDF,一份男打印蓝色手工纸、一份女打印粉色手工纸。

WORD模版

EXCLE(共有8人,其中男有5人,女有3人,男单字卡片15张,女单字卡片10张)

代码展示


'''
20240202中4班描字帖正方形字卡3.0 页眉是黑体 名字用红豆空心黑体+文艺空心黑体 先男后女,手工纸大小
作者:阿夏
时间:2024年12月14日

'''



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步:新建一个临时文件夹------------')

path=r'C:\Users\jg2yXRZ\OneDrive\桌面\描字帖'
# 新建一个”装N份word和PDF“的临时文件夹


gz=23

wb= xlrd.open_workbook(path+r'\学生名单.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  # 第一列去掉第一行

# 初始化计数器
male_count = 0
female_count = 0

# 遍历第4列的值并统计男、女的数量
for value in col4:
    if value == '男':
        male_count += 1
    elif value == '女':
        female_count += 1

print(f"男性数量: {male_count}")
print(f"女性数量: {female_count}")

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)
       
# 需要除以2
print(len(numberall_boy))
print(len(numberall_girl))

numberall=numberall_boy+numberall_girl
print(numberall)
# 需要打印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
print(list1)
print(len(list1))
# 25

# 每页只有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 tt in range(len(typefaceall)):        # 两种字体

    
for t in range(len(list1)): # 86           #  2 
    folder=path+r'\零时Word'
    os.makedirs(folder,exist_ok=True)  # 若图片文件夹不存在就创建

    
    
    doc = docx.Document(path+r'\08(模版)中X班描字帖正方形手工纸分男女.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] #黑体 或 红豆空心黑体,某些格子用黑体,某些格子用红豆
            # run.font.name =typefaceall[tt]  #只用三款                           
            # 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(folder+fr'\{t:02}.docx')#保存为XX学号的零时word
    time.sleep(1)
    from docx2pdf import convert
    # docx 文件另存为PDF文件
    inputFile = folder+fr'\{t:02}.docx'
    outputFile = folder+fr'\{t:02}.pdf'
    # 先创建 不存在的 文件
    f1 = open(outputFile,'w')
    f1.close()
    # 再转换往PDF中写入内容
    convert(inputFile, outputFile)
    time.sleep(2)

    from docx2pdf import convert


print('----------第4步:把都有PDF合并为一个打印用PDF------------')

all=path+r'\20241214中X班单字手工纸'
os.makedirs(all,exist_ok=True)

import os
from PyPDF2 import PdfMerger

pdf_lst = [f for f in os.listdir(folder) if f.endswith('.pdf')]
pdf_lst = [os.path.join(folder, 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(all+fr"\中X班描字卡片不加粗_{typefaceall[1]}_男蓝色{int(len(numberall_boy)/2)}张女粉色{int(len(numberall_girl)/2)}张 ({num}份).pdf")
time.sleep(5)

file_merger.close()

# 只保留男孩名字卡片纸 前20个 PDF 文件
pdf_lst1 = pdf_lst[:int(len(numberall_boy)/2)]
# 创建 PdfMerger 对象
file_merger1 = PdfMerger()
# 打印并添加每个 PDF 文件到合并器中
for pdf1 in pdf_lst1:
    print(pdf1)
    file_merger1.append(pdf1)
file_merger1.write(all+fr"\中X班描字卡片不加粗_{typefaceall[1]}_男蓝色手工纸{int(len(numberall_boy)/2)}张{male_count}人.pdf")
time.sleep(5)
file_merger1.close()

    # 只保留男孩名字卡片纸 后20个 PDF 文件
pdf_lst2 = pdf_lst[int(len(numberall_boy)/2):]
# 创建 PdfMerger 对象
file_merger2 = PdfMerger()
# 打印并添加每个 PDF 文件到合并器中
for pdf2 in pdf_lst2:
    print(pdf2)
    file_merger2.append(pdf2)
file_merger2.write(all+fr"\中X班描字卡片不加粗_{typefaceall[1]}_女粉色手工纸{int(len(numberall_girl)/2)}张{female_count}人.pdf")
time.sleep(5)
file_merger2.close()


# print('----------第5步:删除临时文件夹------------')    
import shutil
shutil.rmtree(folder) #递归删除文件夹,即:删除非空文件夹`
time.sleep(10)

作品展示

一、男女合并PDF字卡(25张)

二、男PDF字卡(15张)

三、女PDF字卡(10张)

用代码把中2班的29位孩子的名字字卡做一遍。

班级里有“玥”“瑄”的名字是没法用红豆空心黑体显示,改成文艺空心黑体

获取的男女人数

生成的数量

男女共29人。男女合并版本 男41张,女44张,合计85个名字(打印85张15CM手工纸),

所有男孩的名字合并(蓝色手工纸打印)41张14人

所有女孩的名字合并(蓝色手工纸打印)44张15人

女孩里面有两个字无法用红豆空心黑体,所以改成文艺空心黑体

1、加粗的文艺空心黑体

2、不加粗的文艺空心黑体

文艺空心黑体,还是加粗把。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿夏reasonsummer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值