【教學類-35-02】20231207大班姓名描字帖:A4單面3*10個姓名,雙面共60個名字

背景需求:

需求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個名字或者繪畫圖案,然后把這些紙片與同伴們交換,玩收集“名片”的游戲(包含學號和名字,來確定還缺那些卡片)

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/207316.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/207316.shtml
英文地址,請注明出處:http://en.pswp.cn/news/207316.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

測試:API接口測試

API接口測試 API接口測試是確保應用程序編程接口(API)在開發過程中正確實現并滿足預定功能要求的過程。API是不同軟件之間交流的橋梁,負責數據的傳輸、交換和控制。進行API測試的目的是驗證API的功能、性能、安全性和兼容性。 API接口測試的…

【Linux系統化學習】進程地址空間 | 虛擬地址和物理地址的關系

個人主頁點擊直達:小白不是程序媛 Linux專欄:Linux系統化學習 代碼倉庫:Gitee 目錄 虛擬地址和物理地址 頁表 進程地址空間 進程地址空間存在的意義 虛擬地址和物理地址 我們在學習C/C的時候肯定都見過下面這張有關于內存分布的圖片&a…

SQL Server 數據庫,多表查詢

4.2使用T-SQL實現多表查詢 前面講述過的所有查詢都是基于單個數據庫表的查詢,如果一個查詢需要對多個表進行操作, 就稱為聯接查詢,聯接查詢的結果集或結果稱為表之間的聯接。 聯接查詢實際上是通過各個表之間共同列的關聯性來查詢數據的&…

微信小程序 bindtap 事件多參數傳遞

在微信小程序中,我們無法直接通過 bindtap"handleClick(1,2,3)" 的方式傳遞參數,而是需要通過自定義屬性 data- 的方式進行傳遞,并在事件回調函數中通過 event.currentTarget.dataset 來獲取這些參數。然而,這種傳參方式…

跨框架解決方案-Mitosis【Context】

Context Mitosis的context必須是: 在自己的文件中創建文件名必須以context.lite.ts結尾默認導出必須是一個返回context對象的函數 // simple.context.lite.ts import { createContext } from builder.io/mitosis;export default createContext({foo: bar,get foo…

速查!軟考出成績了

2023年11月軟考成績出來啦!大家趕緊查一下,各科都45分就是通過! 01 如何查成績 1、打開“中國計算機技術職業資格網”,網址:https://www.ruankao.org.cn/ 2、點擊↘的“成績查詢”按鈕。 3、輸入“手機號/證件號密碼驗…

光伏儲能IC

光伏儲能IC 電子元器件百科 文章目錄 光伏儲能IC前言一、光伏儲能IC是什么二、光伏儲能IC的類別三、光伏儲能IC的應用實例四、光伏儲能IC的作用原理總結前言 光伏儲能IC可以提高光伏發電和儲能系統的效率和穩定性,同時提供智能化的管理和控制功能。它在光伏發電和儲能領域具有…

船舶機電設備智能故障診斷系統

1 船舶電氣設備故障診斷專家系統 體系結構 整個系統的體系結構采用瀏覽器/ 服務器 (B/ S) 三層體系結構 ( 如圖 1 所示 )。B/S 模式是一種 以 Web 技術為基礎的系統平臺模式 。 把傳統…

【GEE】時間序列多源遙感數據隨機森林回歸預測|反演|驗證|散點圖|完整代碼

實驗介紹 分類和回歸之間的主要區別在于,在分類中,我們的預測目標是離散的類別,而在回歸中,預測目標是連續的預測值。 本實驗的研究區域位于佛蒙特州的埃塞克斯郡,使用訓練數據來模擬土壤氧化還原深度,然…

Codeforces Round 851 (Div. 2 D:枚舉+組合 Edp)

A - One and Two 相當于找第一個位置前后2的個數相同 #include<bits/stdc.h> using namespace std; const int N 1e610,mod998244353; #define int long long typedef long long LL; typedef pair<int, int> PII; const long long inf1e17; int n,m,k; int a[N]…

有哪些值得分享的銷售拓客技巧?

拓客對于銷售的重要性 拓客&#xff08;Toker&#xff09;是一個商業上的名詞&#xff0c;核心就是提高售前服務、市場推廣的水平&#xff0c;從而挖掘出潛在客戶的隱形需求&#xff08;或稱軟需求&#xff09;。 拓客的核心&#xff0c;其實就是提高售前服務、市場推廣的水平…

如何部署自己的服務渲染頁面為Pdf文檔

前言 相信大家都覺得官方發布的文檔生成模塊https://docs.mendix.com/appstore/modules/document-generation/很有用&#xff0c;它能把Mendix頁面像素級導出到Pdf文件中&#xff0c;這對于歸檔等業務非常有價值。但部署依賴公有云提供的渲染服務&#xff0c;而中國本土用戶對…

折半查找(數據結構實訓)

題目&#xff1a; 標準輸入輸出 題目描述&#xff1a; 實現折半查找。要求查找給定的值在數據表中相應的存儲位置。本題目假定輸入元素均按非降序輸入。 輸入&#xff1a; 輸入包含若干個測試用例&#xff0c;第一行為測試用例個數k。每個測試用例占3行&#xff0c;其中第一行為…

初識人工智能,一文讀懂過擬合欠擬合和模型壓縮的知識文集(3)

&#x1f3c6;作者簡介&#xff0c;普修羅雙戰士&#xff0c;一直追求不斷學習和成長&#xff0c;在技術的道路上持續探索和實踐。 &#x1f3c6;多年互聯網行業從業經驗&#xff0c;歷任核心研發工程師&#xff0c;項目技術負責人。 &#x1f389;歡迎 &#x1f44d;點贊?評論…

SQL存儲過程和視圖

1 存儲過程 存儲過程是事先編寫好、存儲在數據庫中的一組SQL命令集合。用來完成對數據庫的指定操作。 1.1 優缺點 優點&#xff1a; 1&#xff09;提高系統性能。創建時進行編譯&#xff0c;隨后存放在數據庫服務器的過程高速緩存中&#xff0c;之后不需要再次執行分析和編…

uniapp app將base64保存到相冊,uniapp app將文件流保存到相冊

如果是文件流可以先轉base64詳情見>uniapp 顯示文件流圖片-CSDN博客 onDown(){let base64 this.qrcodeUrl ; // base64地址const bitmap new plus.nativeObj.Bitmap("test");bitmap.loadBase64Data(base64, function() {const url "_doc/" new Dat…

Backend - Dbeaver

目錄 一、說明 二、下載并安裝 &#xff08;一&#xff09;官網下載 &#xff08;二&#xff09;安裝 三、使用 &#xff08;一&#xff09;操作步驟 &#xff08;二&#xff09;相關問題&#xff1a;無法加載驅動類oracle.jdbc.oracledriver 1. 新建驅動 2. 再重新連接數據庫 …

PyTorch2.0環境搭建

一、安裝python并配置環境變量 1、打開python官網&#xff0c;下載并安裝 Welcome to Python.org 下載 尋找版本&#xff1a;推薦使用3.9版本&#xff0c;或其他表中顯示為安全&#xff08;security&#xff09;的版本 安裝&#xff1a;&#xff08;略&#xff09; 2、配置環…

數據增強改進,實現檢測目標copypaste,增加目標數據量,提升精度

???YOLOv8實戰寶典--星級指南:從入門到精通,您不可錯過的技巧 ??-- 聚焦于YOLO的 最新版本, 對頸部網絡改進、添加局部注意力、增加檢測頭部,實測漲點 ?? 深入淺出YOLOv8:我的專業筆記與技術總結 ??-- YOLOv8輕松上手, 適用技術小白,文章代碼齊全,僅需 …

python圣誕樹代碼編程

以下是一個簡單的Python圣誕樹代碼&#xff1a; def draw_tree(height): for i in range(height): print( * (height - i - 1) * * (2 * i 1)) print( * (height - 1) |)draw_tree(10) 這個函數會繪制一個等腰三角形&#xff0c;其中每一行的星號數量從1開…