背景需求:
需求1——需要字帖
大4班班主任說:你能給我們班孩子做一套寫名字的字帖嗎?我想讓他們練習寫名字。
我說:沒問題。我找找已經有的樣式給你看看,再打印。
打開電腦,我把曾經做的一套“大字貼”發給她看看樣板。
需求2——限定內容和數量
班主任看了模板,提出需求:
1、不要學號、班級
2、每頁20個姓名
我重新做了一個word模板,修改bg單元格的數字。嵌套數組的數量、把字號調到最大。
打印一份名字筆畫最多的,把紙片拿給班主任看
班主任說ok?
但是看著PDF,我感覺2*10的格子,名字左右有空格較多,有點浪費。
需求3——嘗試3列*10行=30個名字
由于班級所有孩子都2-3個名字,所以我試試做成3列
客戶表示也行。
需求4:嘗試正反兩頁共打印60個名字
于是我把單元格改成從2列變成3列,名字正好寫入
可以打印了,一共要打印31份。
但是最近用廢紙反面打印了很多加減法題,我手里已經沒有廢紙了。
只能用兩面空白的紙,我有點心疼,
干脆A4兩面都打印名字吧,讓孩子多練習幾次(一面30個名字,兩面60個名字)
最終設計了兩頁3*20行的字帖模板
素材準備;
EXCEL
WORD素材
以3列20行60字為例
如果是2列10行20字,3列10行30字,也是這樣的參數,就是行列刪除一些
代碼展示:
'''
作者:阿夏
時間:20231207
名稱:大4 60個名字(30一面,正反打印).py
'''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 qnfrom docxtpl import DocxTemplate
import pandas as pd
from docx2pdf import convert
from docx.shared import RGBColor# 需要幾行已有文字
nn=int(input('一共幾行(20行、10行)\n'))
mm=int(input('一共幾列(2列、3列)\n'))
# 空格數量wb= xlrd.open_workbook(r"C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\學生名單.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(col2)-1 # 第一列去掉第一行list=[]
# 生成 基本組:“名字“
for i in range(1,len(col2)):for d in range(nn*mm): # 要幾行b1=col2[i] #姓名list.append(b1)print(list)# 60個名字bg=[]
for x in range(0,nn): # 10行for y in range(0,mm): # 2列c='{}{}'.format('%02d'%x,'%02d'%y)bg.append(c)
print(bg)
print(len(bg))listall=[]
for o in range(int(len(list)/(nn*mm))):d=list[o*nn*mm:o*nn*mm+nn*mm]listall.append(d)
print(listall)
print(len(listall))print('----------第1步:新建一個臨時文件夾------------')
# 新建一個”裝N份word和PDF“的文件夾
dir_name=r'C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\零時Word'
if not os.path.exists(dir_name):os.mkdir(dir_name)# doc= docx.Document(r"C:\Users\jg2yXRZ\OneDrive\桌面\描字貼\打印合集描字貼.docx")# 新建Wordfor n in range(int(len(listall))): # 一共多少份doc = docx.Document(r"C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\20231207大四 {}個名字.docx".format(nn*mm))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=listall[n][p] # 從4名字里提取名字\print(pp,qq,k)run=table.cell(pp,qq).paragraphs[0].add_run(k) # 在單元格0,0(第1行第1列)輸入第0個名字run.font.name = '黑體' #輸入時不同字體run.font.size = Pt(60) #輸入字體大小80或68號run.Bold=Truerun.font.color.rgb = RGBColor(200,200,200) #設置顏色10%黑色=深灰r = run._elementr.rPr.rFonts.set(qn('w:eastAsia'), '黑體' )#將輸入語句中的中文部分字體變為華文行楷table.cell(pp,qq).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.CENTER #居中doc.save(r'C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\零時Word\{}.docx'.format('%02d'%n))#保存為XX學號的零時wordtime.sleep(2)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)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班名字60個({}份).pdf".format(len(col2)-1))
file_merger.close()
# doc.Close()# # print('----------第5步:刪除臨時文件夾------------')
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/描字帖/零時Word') #遞歸刪除文件夾,即:刪除非空文件夾`
終端輸入:
效果展示:
打印效果
雙面的名字貼,可以描2次-4次哦
不能用記號筆,只能用鉛筆或者熒光筆、水筆寫。
感悟:
1、在大四班帶班,所以知道這個班級一半孩子會默寫自己的名字。
2、但是不會寫的孩子,還是需要“畫“名字。同時需要家長告訴孩子正確的筆畫序,矯正書寫順序。。
這是我第2次收到同事對幼兒紙類學具的主動需求,希望有更多的老師能看到我的Python學具設計,結合自身需要提出要求。
3、這份學具也給我啟發,想出一個“名片游戲”——中大班孩子們描30個名字,然后把紙片裁剪開來(用切紙機,剪起來不整齊,廢紙多),然后在空白反面自己默寫1-3個名字或者繪畫圖案,然后把這些紙片與同伴們交換,玩收集“名片”的游戲(包含學號和名字,來確定還缺那些卡片)