作品展示
背景需求:
給大4班17號同學單獨做了一個學號字帖后,我想可以把這樣的學具用在中班(我馬上要成為中4班老師了),那就需要給全班做一份這樣的大號學號貼。
使用17號同學的word模板(見下文),代碼修改成嵌套數組格式
【教學類-35-05】17號的學號字帖(A4豎版1份)-CSDN博客文章瀏覽閱讀37次。【教學類-35-05】17號的學號字帖(A4豎版1份)https://blog.csdn.net/reasonsummer/article/details/134888067
代碼展示:
'''
作者:阿夏
時間:20231207
名稱:大4 所有學號的字帖(01-09去0)
'''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('一共幾行(8行、其中4行是兩個數字,4行是1組數字)\n'))
mm=int(input('一共幾列(6列)\n'))
kk=int(input('需要空幾行(讓幼兒自由書寫用(最少1行,最多3行)\n'))
xh=int(input('學號總數,如一共32人,就輸入32\n'))# s=int(input('請輸入學號(17)\n'))# 所有31個學號
s=[]
for z in range(1,xh+1):f='%02d'%zs.append(f)
print(s)
# ['01', '02']# 空格數量
# # 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(2)# 名字
# # col3=sheet.col_values(2)# 班級
# num=len(col2)-2 # 第一列去掉第一行# 插入標題的坐標和內容
# bg.insert(0,zb)# 分開的學號
w=int((nn/2-kk)*mm) # 8行的一半=4行,4行中的3行有數字,1行無數字
kg='' # 空格
# 有學號的部分
list=[]
lista=[]for aa in range(len(s)):list.clear()# listall.clear()for a1 in range(0,w): if s[aa][0]=='0': # 如果十位數==0,就輸入個位數的數字,也就是十位數和個位數都一樣,如果是06,就寫入6,list.append(s[aa][1])else: # 如果十位數不等于0,輸入十位數數字 如12,就寫入1list.append(s[aa][0])list.append(s[aa][1])# 空行部分for c in range(2): for b1 in range(kk*mm):list.append(kg)# print(list1)for a2 in range(0,w):if s[aa][0]=='0':# 如果十位數==0,就輸入個位數的數字,后四行單元格里面都是一個數字,如果是03,就寫入3,不管0了。list.append(s[aa][1])else: # 如果十位數不等于0,輸入十位數+個位數數字 如果是23,寫入23list.append(s[aa])# 空行部分for b2 in range(kk*mm):list.append(kg)bt='我的學號是:{}'.format(int(aa+1))list.insert(0,bt)print(list)# 讀取list每一個for i in list:lista.append(i)
# c=list
# listall.append(list)
print(lista)# # 分成一組一組的
listall=[]
for ii in range(int(len(lista)/73)):listall.append(lista[ii*73:ii*73+73])
print(listall)
print(len(listall))# 制作所有單元格的數字
# 前4行的坐標
bg1=[]
for x1 in range(1,int(nn/2)+1): # 8/2=4行 第一行是標題,所以從索引1(第2行開始)for y1 in range(0,mm*2): #6列*2 數字拆開的2份,所以是12格子c1='{}{}'.format('%02d'%x1,'%02d'%y1)bg1.append(c1)
print(bg1)
print(len(bg1))# 后4行的坐標
bg2=[]
for x2 in range(1+int(nn/2),nn+1): # 從第5行開始,到第8行+1for y2 in range(0,mm*2,2): #6列*2 0-12 之間,所有的0,2,4,6坐標c2='{}{}'.format('%02d'%x2,'%02d'%y2)bg2.append(c2)
print(bg2)
print(len(bg2))# 標題坐標
zb='0000'# 一頁所有的坐標
bg=bg1+bg2
bg.insert(0,zb)
print(bg)
print(len(bg))print('----------第1步:新建一個臨時文件夾------------')
# 新建一個”裝N份word和PDF“的文件夾
dir_name=r'C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\17號的數字練字帖\零時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(len(s)): # 一共多少份doc = docx.Document(r"C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\17號的數字練字帖\17號的學號字帖.docx")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名字里提取名字\# pp=int(bg[p][0:2]) # 提取表格bg里面每個元素的第0個數字==單元格X坐標 t=索引數字# qq=int(bg[p][2:4]) # # f=font[t] # 字體格式# k=list[p] # 只有一個,所以不要nprint(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(61) #輸入字體大小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\桌面\描字帖\17號的數字練字帖\零時Word\{}.docx'.format('%02d'%n))#保存為XX學號的零時wordtime.sleep(2)from docx2pdf import convert# docx 文件另存為PDF文件inputFile = r"C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\17號的數字練字帖\零時Word\{}.docx".format('%02d'%n)# 要轉換的文件:已存在outputFile = r"C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\17號的數字練字帖\零時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/桌面/描字帖/17號的數字練字帖/零時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/桌面/描字帖/17號的數字練字帖/(打印合集)全部學號的數字練字帖去0({}份).pdf".format(len(s)))
file_merger.close()
# doc.Close()# # print('----------第5步:刪除臨時文件夾------------')
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/描字帖/17號的數字練字帖/零時Word') #遞歸刪除文件夾,即:刪除非空文件夾`
終端輸入:
本代碼重點說明——01-09去0
? ? ?由于幼兒的鏡像視力,因此我放棄了在01-09學號前加0的打算,但是本學具前4行涉及到2個數字拆分,因此1-9只有一個數字,就會程序報錯,所以,還是生成01-09,但借助if判斷,讓1-9的數字變成11 22 33 44……99的樣式,確保幼兒都能練習更多的“自己的學號數字”
前4行:如果十位數是0,就寫入個位數數字
后4行:如果十位數是0,就寫入十位數和個位數全部數字