【教学类-35-21】20240901 中2班描字帖(学号+姓名、虚拟姓名、杨任东竹石体 Regular)

本文主要是介绍【教学类-35-21】20240901 中2班描字帖(学号+姓名、虚拟姓名、杨任东竹石体 Regular),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景需求:

8月底通知我成为中2班的班主任,为了快速识别幼儿的脸、姓名、学号,再次制作描字帖,并拍照。

最近做的一份字帖是中4班描字帖

【教学类-35-20】20240328 中4班描字帖(学号+姓名 A4竖版2份 横面)+裁剪纸条+插入式纸盒-CSDN博客文章浏览阅读643次,点赞16次,收藏7次。【教学类-35-20】20240328 中4班描字帖(学号+姓名 A4竖版2份 横面)+裁剪纸条+插入式纸盒https://blog.csdn.net/reasonsummer/article/details/137117098?csdn_share_tail=%7B%22type%22%3A%22blog%22%2C%22rType%22%3A%22article%22%2C%22rId%22%3A%22137117098%22%2C%22source%22%3A%22reasonsummer%22%7D

考虑带中4班时,他们已经是下学期了,所以描汉字,现在是中2班孩子是上学期,所以我就只让他们描学号数字

微软雅黑的“1”有一个弯钩(其他数字都符合书写标准),所以这次我想换掉常用的加粗字体“微软雅黑”,选择“杨任东竹石体 Regular”

【教学类-44-11】20240324 杨任东竹石体 Regular(实线字体)制作的数字描字帖(AI对话大师缩略版)-CSDN博客文章浏览阅读1k次,点赞37次,收藏20次。【教学类-44-11】20240324 杨任东竹石体 Regular(实线字体)制作的数字描字帖(AI对话大师缩略版)https://blog.csdn.net/reasonsummer/article/details/137022370?csdn_share_tail=%7B%22type%22%3A%22blog%22%2C%22rType%22%3A%22article%22%2C%22rId%22%3A%22137022370%22%2C%22source%22%3A%22reasonsummer%22%7D

“杨任东竹石体 Regular”的1符合书写习惯,但是9的斜线弯曲,应该是直线

素材模版

第一步:修改WORd模板

把最上面的学号姓名格子变成隐藏框线

第二步 制作学生名单

为了保护隐私,我用星火讯飞,随机生成29个名字(班里只有2-3个字的名字,就不考虑4个字名字)

'''
随机生成汉字姓名2-3个字
星火讯飞 阿夏
20240901
'''import random# 姓氏列表
surnames = ['赵', '钱', '孙', '李', '周', '吴', '郑', '王', '冯', '陈', '褚', '卫', '蒋', '沈', '韩', '杨', '朱', '秦', '尤', '许']
# 名字列表
names = ['大伟', '芳', '娜', '敏静', '秀英', '丽', '国强', '磊', '洋', '艳', '大勇', '建军', '人杰', '娟', '涛', '超', '明', '霞', '国平', '英刚', '桂英', '志明', '建国', '建华', '春梅']# 生成名字函数
def generate_name():name = ''# 随机选择姓氏和名字长度length = random.choice([2, 3])if length == 2:name += random.choice(surnames) + random.choice(names)else:name += random.choice(surnames) + random.choice(names) return name# 生成29个名字
names = [generate_name() for _ in range(29)]
print(names)# ['褚静', '蒋霞娜', '秦伟', '钱建国娟', '王强娟', '周娜娟', '卫丽强', '蒋志明', '褚娟静', '郑军静', '钱涛刚', '卫明', '韩艳军', '杨艳', '尤建国磊', '尤伟', '李芳', '褚敏', '李军', '沈涛静', '褚伟志明', '韩超', '周丽勇', '卫建华敏', '郑春梅涛', '许伟', '许桂英洋', '褚刚', '陈建华']
# ['杨丽', '赵伟娟', '赵勇平', '王静', '蒋静芳', '赵超', '孙志明', '许强', '尤明秀英', '韩刚春梅', '许强', '沈桂英伟', '许娜芳', '沈娟', '吴洋桂英', '王涛', '王丽', '秦刚', '冯明建华', '褚建国', '杨娜强', '郑丽杰', '韩秀英芳', '卫艳', '蒋敏秀英', '周静娟', '尤桂英', '褚明', '蒋平']for n in names:print(n)

每次生成的名字都不同。

我用了这一套29个名字,复制到EXCLE学生给名单里

(因为只有29个学生,是单数,本代码必须是双数才能复制,因此将29号复制了一次)

代码展示


'''
20240901中2班描字帖
作者:阿夏
时间:2024年9月1日
学号和姓名分开
'''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“的临时文件夹
path=r'C:\Users\jg2yXRZ\OneDrive\桌面\描字帖'
new_path=path+r'\20240901中2班学号描字帖'wb= xlrd.open_workbook(new_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)# 班级
num=len(col1)-1  # 第一列去掉第一行numberall=[]
# 生成 基本组:“学号+名字“
for num in range(1,len(col1)):for x0 in range(1):name00=str(int(col1[num])) +str(col2[num])     #学号和名字拼在一起, 1 张三numberall.append(name00)for x1 in range(16):number1=int(col1[num])numberall.append(number1)        # 只要学号for x2 in range(8):b=' 'numberall.append(b)  # 学号留两个空print(numberall)
# 一个数组【】gz=25
# 切开25人 一人16个数字
list1=[]
for fk in range(int(len(numberall)/gz)):    # 一共26格子list1.append(numberall[fk*gz:fk*gz+gz])
print(list1)
print(len(list1))lists=[]
for r in range(int(len(list1)/2)):lists.append(list1[r*2:r*2+2])
print(lists)
print(len(lists))# # 25个数组【】bg=[]
# 第一行的格子
a=['0000']
for z1 in a:bg.append(z1)
# 第2-3行学号的格子16格子
for x in range(1,4):for y in range(0,8):z2='{}{}'.format('%02d'%x,'%02d'%y)bg.append(z2)print(bg)
print(len(bg))
# # ['0000', '0004', '0100', '0101', '0102', '0103', '0104', '0105', '0106', '0107', '0200', '0201', '0202', '0203', '0204', '0205', '0206', '0207', '0300', '0302', '0304', '0306', '0400', '0402', '0404', '0406']T=[120,45]
F=['微软雅黑','杨任东竹石体-Regular']
for f in F:target_path=path+r'\零时Word'if not os.path.exists(target_path):  # 判断存放图片的文件夹是否存在os.makedirs(target_path)  # 若图片文件夹不存在就创建for n in range(int(num/2)):doc = docx.Document(new_path+r"\中2班描字帖.docx")for b in range(2):table = doc.tables[b] # print(p)for t in range(len(bg)):    # 0-gz# print(list[t])pp=int(bg[t][0:2])     # 提取表格bg里面每个元素的第0个数字==单元格X坐标  t=索引数字qq=int(bg[t][2:4]) k=lists[n][b][t]# f=font[t]   print(pp,qq,k)if pp==0 and qq==0:run=table.cell(pp,qq).paragraphs[0].add_run(str(k))    # 在单元格0,0(第1行第1列)输入第0个名字run.font.size = Pt(T[0])  #输入字体大小80或68号run.font.name = f  #输入时不字体# run.bold=Truerun.font.color.rgb = RGBColor(220,220,220) #设置颜色10%黑色=深灰r = run._elementr.rPr.rFonts.set(qn('w:eastAsia'), f )#将输入语句中的中文部分字体变为华文行楷table.cell(pp,qq).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.CENTER #居中else:run=table.cell(pp,qq).paragraphs[0].add_run(str(k))    # 在单元格0,0(第1行第1列)输入第0个名字run.font.size = Pt(T[1])  #输入字体大小80或68号run.font.name = f  #输入时不字体# run.bold=Truerun.font.color.rgb = RGBColor(200,200,200) #设置颜色10%黑色=深灰r = run._elementr.rPr.rFonts.set(qn('w:eastAsia'),f )#将输入语句中的中文部分字体变为华文行楷table.cell(pp,qq).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.CENTER #居中doc.save(r'C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\零时Word\{}.docx'.format('%02d'%n))#保存为XX学号的零时word  time.sleep(1)from docx2pdf import convert# docx 文件另存为PDF文件inputFile = r"C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\零时Word\{}.docx".format('%02d'%n)# 要转换的文件:已存在outputFile = r"C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\零时Word\{}.pdf".format('%02d'%n)  # 要生成的文件:不存在# 先创建 不存在的 文件f1 = open(outputFile,'w')f1.close()# 再转换往PDF中写入内容convert(inputFile, outputFile)time.sleep(1)from docx2pdf import convertprint('----------第4步:把都有PDF合并为一个打印用PDF------------')import osfrom PyPDF2 import PdfMergerpdf_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(path+fr"\(打印合集)中2班描字帖练习册({num}份{f}).pdf")file_merger.close()# doc.Close()# # print('----------第5步:删除临时文件夹------------')    import shutilshutil.rmtree(target_path) #递归删除文件夹,即:删除非空文件夹`

生成时间很长……

重点说明:

1、本次描字帖的名字字号很大,学号字号较小

2、为了能够挑选,我做了两套字体——微软雅黑和杨任东竹石体

生成文件

效果展示

1、微软雅黑字帖


必须双数

2、杨任东竹石体字帖

字体样式比较分析

1.杨任东字体更好看,符合书写的样式,但是它显示出来的字体大小始终比同样字号的微软雅黑小。

2.不过我之前都是用微软雅黑或黑体,都是加粗字体,本次就想试试杨仁东字体这种线条细腻的字体,看看幼儿描写的效果。

结论:还是打印“杨任东竹石体”的描字帖

这篇关于【教学类-35-21】20240901 中2班描字帖(学号+姓名、虚拟姓名、杨任东竹石体 Regular)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1128449

相关文章

VMWare报错“指定的文件不是虚拟磁盘“或“The file specified is not a virtual disk”问题

《VMWare报错“指定的文件不是虚拟磁盘“或“Thefilespecifiedisnotavirtualdisk”问题》文章描述了如何修复VMware虚拟机中出现的“指定的文件不是虚拟... 目录VMWare报错“指定的文件不是虚拟磁盘“或“The file specified is not a virt

【LabVIEW学习篇 - 21】:DLL与API的调用

文章目录 DLL与API调用DLLAPIDLL的调用 DLL与API调用 LabVIEW虽然已经足够强大,但不同的语言在不同领域都有着自己的优势,为了强强联合,LabVIEW提供了强大的外部程序接口能力,包括DLL、CIN(C语言接口)、ActiveX、.NET、MATLAB等等。通过DLL可以使用户很方便地调用C、C++、C#、VB等编程语言写的程序以及windows自带的大

『功能项目』战士的平A特效【35】

我们打开上一篇34武器的切换实例的项目, 本章要做的事情是在战士的每次按A键时在指定位置生成一个平A特效 首先将之前下载的技能拖拽至场景中 完全解压缩后重命名为AEffect 拖拽至预制体文件夹 进入主角动画的战士动画层级 双击第一次攻击 选择Animation 创建事件 创建的动画事件帧放在攻击动画挥剑指定处 命名为PerpetualAtt

【JavaScript】LeetCode:21-25

文章目录 21 最大子数组和22 合并区间23 轮转数组24 除自身以外数组的乘积25 缺失的第一个正数 21 最大子数组和 贪心 / 动态规划贪心:连续和(count)< 0时,放弃当前起点的连续和,将下一个数作为新起点,这里提供使用贪心算法解决本题的代码。动态规划:dp[i]:以nums[i]为结尾的最长连续子序列(子数组)和。 dp[i] = max(dp[i - 1]

文章解读与仿真程序复现思路——电力自动化设备EI\CSCD\北大核心《考虑燃料电池和电解槽虚拟惯量支撑的电力系统优化调度方法》

本专栏栏目提供文章与程序复现思路,具体已有的论文与论文源程序可翻阅本博主免费的专栏栏目《论文与完整程序》 论文与完整源程序_电网论文源程序的博客-CSDN博客https://blog.csdn.net/liang674027206/category_12531414.html 电网论文源程序-CSDN博客电网论文源程序擅长文章解读,论文与完整源程序,等方面的知识,电网论文源程序关注python

react笔记 8-21 约束性 表单

1、约束性组件和非约束性组件 非约束性组件<input type="text" name="" defaultValue={this.state.msg}></input>这里他的value是用户输入的值 并没有执行操作 只是获取到了msg的值 用户输入不会改变数据非约束性组件需要使用defaultValue获取数据 否则会报错约束性组件<input type="text

AF透明模式/虚拟网线模式组网部署

透明模式组网 实验拓扑  防火墙基本配置 接口配置 eth1  eth3   放通策略  1. 内网用户上班时间(9:00-17:00)不允许看视频、玩游戏及网上购物,其余时 间访问互联网不受限制;(20 分) 应用控制策略   2. 互联网用户只允许访问内网两台服务器的 WEB、SSH 和远程桌面服务,其余 服务均不允许访问;(20 分) 外网访问内网的限制策略   虚拟网线模式组网 实

《教学与管理》

《教学与管理》系国家新闻出版总署批准,面向国内外公开发行的教育类学术期刊。《教学与管理》国际标准刊号ISSN1004-5872,国内统一刊号CN14-1024/G4。 教学与管理来稿注意事项 ■本刊主要设有“理论研究、教育观察、办学改革、学校管理、班级管理、教研活动、教育法制、德育建设、课程建设、教学研究、教学方法、教材研究、教学评价、学法指导、考试研究、比较教育”等栏目。 ■本刊读者对象为

leetcode#10. Regular Expression Matching

题目 Implement regular expression matching with support for ‘.’ and ‘*’. '.' Matches any single character.'*' Matches zero or more of the preceding element.The matching should cover the entire input

2025年25届计算机毕业设计:如何实现高校实验室Java SpringBoot教学管理系统

✍✍计算机毕业编程指导师** ⭐⭐个人介绍:自己非常喜欢研究技术问题!专业做Java、Python、微信小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目:有源码或者技术上的问题欢迎在评论区一起讨论交流! ⚡⚡ Java、Python、微信小程序、大数据实战项目集 ⚡⚡文末获取源码 文章目录 ⚡⚡文末获取源码高校实验室教学管理系统-研究背景高校实验室教学管理系