【教学类-35-01】学号+姓名+班级(描字帖)A4一页
背景说明:
本学期我带机动班,其中大4班去的频率比较高,与是我用大四班的名单做了一份
“描字帖”,在9月1日第一天见面时,孩子们用记号笔描字帖时,我也可以对这些孩子初步混个眼熟(聪明的:线条流畅有创意、能力最弱的:线条抖动)
学具样式:
(1)描字内容、学号、姓名、班级
(2)A4竖版,7行,前3行有灰色字体(黑体80磅,撑满了,不能再大了),后4行为空白,边框为灰色
(3)大4班都是三个名字,所以都是黑体80磅,不需要单独做四字名字

代码准备

EXCLE名单


WORD模板



代码展示py
'''
作者:阿夏
时间:2023年8月28日
名称:大四班级姓名学号)
'''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 RGBColorwb= 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(col1)-1 # 第一列去掉第一行list=[]
# 生成 基本组:“学号“
for i in range(1,len(col1)):for d in range(3):a1='{}'.format ('%02d'%col1[i]) #学号list.append(a1)b1=col2[i] #学号list.append(b1)c1=col3[i] list.append(c1)for f in range(12):b=''list.append(b)
print(list)# 32个名字bg=[]
for x in range(0,7):for y in range(0,3):c='{}{}'.format(x,y)bg.append(c)
print(bg)listall=[]
for o in range(int(len(list)/21)):d=list[o*21:o*21+21]listall.append(d)
print(listall)print('----------第1步:新建一个临时文件夹------------')
# 新建一个”装N份word和PDF“的文件夹
os.mkdir(r'C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\零时Word')
# doc= docx.Document(r"C:\Users\jg2yXRZ\OneDrive\桌面\描字贴\打印合集描字贴.docx")# 新建Wordfor n in range(int(len(listall))): # 一共多少份doc = docx.Document(r"C:\Users\jg2yXRZ\OneDrive\桌面\描字帖\学号班级名字.docx")table = doc.tables[0] for p in range(0,len(bg)): # 一共有9个表格pp=int(bg[p][0]) # 提取表格bg里面每个元素的第0个数字==单元格X坐标 t=索引数字qq=int(bg[p][1]) # 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(80) #输入字体大小80或68号run.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学号的零时wordfrom 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 PdfFileMerger
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 = PdfFileMerger()
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班学号名字班级({}份).pdf".format(len(col1)-1))
file_merger.close()
# doc.Close()# # print('----------第5步:删除临时文件夹------------')
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/描字帖/零时Word') #递归删除文件夹,即:删除非空文件夹`
终端运行
直接运行,不用输入参数

结果展示



打印效果:



教学过程
时间:2023年9月1日 15:00-15:30
班级:大4班
人数:25人(实际32人)
活动导入:
1、纸片上有什么?
A:有相同的字(都是4)
B:上面有一样的字,下面没有。
C:大4,我们现在是大4了!
2、这里学号。
师:”这位小朋友学号是多少?
很多孩子说:30号师:这是03,可能你们看到的是30,(镜像视力)。
为了让这个3撑满格子,我在前面加了0,实际上03就是3,
C:0是空的,不算的。
师:对,3号同学是谁呢?
F:是XXX
师:这是3号XXX的描字帖,每个人都有一份你学号和名字的字帖。
会写学号的孩子举手:24人
不会写学号的孩子举手:1人,
师:真的不会写?你的学号多少,我给你做一张专门的学号字帖。
C:我不知道我的学号
D:我是18号,他大概是17号的吧。
3、有几位同学会写名字?会写1个字也算会写
5位孩子举手,4位是女孩(这几个孩子写字画画的线条流畅)
随机生成:既然大部分小朋友都不会写名字,那么降低难度,只要小朋友写学号一列、大4一列、中间的名字,只要用记号笔描3行,就可以了。
E:老师,我不会写学号!
F:老师,我不会写名字
G:可以描字,就像画画一样!把灰色线画成黑色就可以。
E:我不会!
F:等会儿老师单独教你。(大班毕竟画过两年的绘画,肯定绘画描线的基础。单独指点一下如何描线)
4、发描字帖,发到3号,感觉速度太慢
师:我发的太慢了,谁认识小朋友的学号,帮我一起发。
陆续1男2女站起来要求发纸片。
男孩模仿老师喊学号,由于镜像视力,30念成03,27念成21……今天7位孩子没有来,男孩喊了几句后,就放弃,“老师,26号给你”


找不到的10份桌子上,有机灵的孩子主动上来让没有拿到纸的孩子自己来拿。
三位孩子不知道要做什么,没有拿到也乖乖坐着,直到老师提示,才去讲台上挑选自己的描字帖。
描写开始:
(个人信息太多了,所以就稍微放几张照片吧)



特色创意



三位男孩完成全部名字书写(名字相对笔画少)



普遍性的绘画结果





创意绘画内容:












幼儿放在讲台上的作品拍照



教学反思:
今天的描字活动,我感受到大四班孩子的一些特点:
1、描画行为基本普及:幼儿经过老师提示、观摩同伴行为后,都能逐步把灰色字描成黑色,描字态度认真专注,说明家庭中的前书写练习已经普及(捏笔、描线等)
2、名字书写上的能力差异:部分男孩将自己简单的名字全部完成(7个)很多孩子由于名字本身的笔画难度、日常练习频率,自身手指肌群力量,,无法完成大量汉字书写。纷纷表示“老师,我不想再写了名字了!”““那你把学号和班级写一列,可以吗”,通常幼儿都能够接受写学号和画班级(大4)——因为笔画简单
3、学具留白很重要:基于幼儿能力特点和兴趣,我鼓励幼儿在中间空白处自行创意绘画。效果不错,幼儿对于自己感兴趣的“单元格”绘画还是创意满满,人人不同。其中由于15号把看不清楚的“灰色格子”描黑线,而产生了“棋盘格“的效果,后续他在棋盘格内绘画单元格图案,实现了”“电脑键盘”的样式,这个情节吸引了5位孩子效仿,产生了新的游戏动机。
4、足够的选择空间:画完后,孩子们问我怎么处理,我说“可以反面画,或者折叠放书包带回家”,大部分孩子立刻折叠纸张塞书包内、或者卷纸塞书包口袋里,2位女孩看到纸张反面的一堆打印字,就没有兴趣绘画了,但还是涂上几笔(写个学号),然后再这些放书包。
5、男女绘画兴趣不同、内容有差异(涂鸦、几何、抽象)了解不同孩子的绘画能力和兴趣。
6、个别儿童指导;:学号描字帖(21、17号,单独制作一份),先让弱势孩子学会写自己的学号。
7、观察学具结果,记忆幼儿信息。我一直他人的脸和名字记忆不深刻(脸盲),但是学号结合字帖照片,就容易生动直观记忆那些孩子的能力最强,那些孩子能力最弱,快速记忆两端的孩子的学号,提升“人、学号、名字”的认知速度。
感悟:
千变万化的python学具设计(描线、临摹、留空绘画),
带来随机应变的教学过程(必须写的学号和班级、可以少写的名字、可以画画)
逐渐拉平集体教学活动中的差异化,
让每个孩子在教学活动中都能长时间有事可做(参与感,画写剪)
让老师对每个孩子都有话可夸(学习行为、学习品质、互动互助行为)
大家都以自己的速度逐步成长!
相关文章:
【教学类-35-01】学号+姓名+班级(描字帖)A4一页
背景说明: 本学期我带机动班,其中大4班去的频率比较高,与是我用大四班的名单做了一份 “描字帖”,在9月1日第一天见面时,孩子们用记号笔描字帖时,我也可以对这些孩子初步混个眼熟(聪明的&#x…...
UE5 里的一些常用的了解
# ACharacter、APawn的继承关系 ACharacter -继承自-> APawn -继承自-> AActor和 INavAgentInterface AActor -继承自-> UObject -继承自->UObjectBaseUtility -继承自-> UObjectBase(一个独立的类)INavAgentInterface是一个独立的类 #…...
【网络安全带你练爬虫-100练】第19练:使用python打开exe文件
目录 一、目标1:调用exe文件 二、目标2:调用exe打开文件 一、目标1:调用exe文件 1、subprocess 模块允许在 Python 中启动一个新的进程,并与其进行交互 2、subprocess.run() 函数来启动exe文件 3、subprocess.run(["文件路…...
【2D/3D RRT* 算法】使用快速探索随机树进行最佳路径规划(Matlab代码实现)
💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...
用反射实现自定义Java对象转化为json工具类
传入一个object类型的对象获取该对象的class类getFields方法获取该类的所有属性对属性进行遍历,并且拼接成Json格式的字符串,注意:通过属性名来推断方法名获取Method实例通过invoke方法调用 public static String objectToJsonUtil(Object o…...
rk3568 nvme硬盘分区,格式化,挂载测试
前言 环境介绍: 1.编译环境 Ubuntu 18.04.5 LTS 2.SDK rk356x_linux 3.单板 迅为itop-3568开发板 自制底板 一、查看硬盘 插上硬盘上电,进入系统后通过命令lspci查看nvme硬盘识别情况 [rootRK356X:/]# lspci -k 21:00.0 Class 0108: 1e4b:1202…...
Failed to load ApplicationContext解决办法,spring版本问题
有如下报错: "D:\Program Files\Java\jdk-13.0.1\bin\java.exe" -agentlib:jdwptransportdt_socket,address127.0.0.1:7325,suspendy,servern -ea -Didea.test.cyclic.buffer.size1048576 -Dfile.encodingUTF-8 -classpath "D:\Program Files\JetBr…...
Is f(z)=1/z truly an analytic function
https://math.stackexchange.com/questions/755566/is-fz-1-z-truly-an-analytic-function...
代理模式 静态代理和动态代理(jdk、cglib)——Java入职第十一天
一、代理模式 一个类代表另一个类去完成扩展功能,在主体类的基础上,新增一个代理类,扩展主体类功能,不影响主体,完成额外功能。比如买车票,可以去代理点买,不用去火车站,主要包括静态代理和动态代理两种模式。 代理类中包含了主体类 二、静态代理 无法根据业务扩展,…...
Remmina在ubuntu22.04中无法连接Windows
Remmina在ubuntu22.04中无法连接Windows 问题 提示为: 无法通过TLS到RDP服务器… 分析 原因是Remmina需要使用openssl通过RDP加密与Windows计算机连接,而ubuntu22.04系统中OpenSSL版本为3.0,Openssl3 将 tls<1.2 和 sha1 的默认安全级别…...
【uniapp】this有时为啥打印的是undefined?(箭头函数修改this)
😉博主:初映CY的前说(前端领域) ,📒本文核心:uniapp中this指向问题 前言:this大家知道是我们当前项目的实例,我们可以在这个this上面拿到我们原型上的全部数据。这个常用在我们在方法中调用其他方法使用。 …...
2023高教社杯数学建模思路 - 复盘:光照强度计算的优化模型
文章目录 0 赛题思路1 问题要求2 假设约定3 符号约定4 建立模型5 模型求解6 实现代码 建模资料 0 赛题思路 (赛题出来以后第一时间在CSDN分享) https://blog.csdn.net/dc_sinor?typeblog 1 问题要求 现在已知一个教室长为15米,宽为12米&…...
河道漂浮物检测:安防监控/视频智能分析/AI算法智能分析技术如何助力河道整治工作?
随着社会的发展和人们生活水平的进步,水污染问题也越来越严重,水资源监管和治理成为城市发展的一大困扰,水面上的漂浮垃圾不仅会影响河道生态安全并阻碍船舶航行,还会影响人们的身体健康。 TSINGSEEE青犀AI智能分析平台在环保场景…...
Dubbo 应用切换 ZooKeeper 注册中心实例,流量无损迁移
首先思考一个问题:如果 Dubbo 应用使用 ZooKeeper 作为注册中心,现在需要切换到新的 ZooKeeper 实例,如何做到流量无损? 本文提供解决这个问题的一种方案。 场景 有两个基于 Dubbo 的微服务应用,一个是服务提供者&…...
ADB入门教程
安卓开发 文章目录 安卓开发前言USB 连接链接 前言 基本用法 命令语法 adb 命令的基本语法如下: adb [-d|-e|-s <serialNumber>] <command>如果只有一个设备/模拟器连接时,可以省略掉 [-d|-e|-s ] 这一部分,直接使用 adb 。 为…...
SQLPro Studio for Mac:强大的SQL开发和管理工具
SQLPro Studio for Mac是一款强大的Mac上使用的SQL开发和管理工具,它支持各种数据库,包括MySQL,PostgreSQL,SQLite等。使用 SQLPro Studio,您可以轻松地连接和管理您的数据库,执行SQL查询和脚本,…...
淘宝API技术解析,实现按图搜索淘宝商品
淘宝提供了开放平台接口(API)来实现按图搜索淘宝商品的功能。您可以通过以下步骤来实现: 1. 获取开放平台的访问权限:首先,您需要在淘宝开放平台创建一个应用,获取访问淘宝API的权限。具体的申请步骤和要求…...
错误:依赖检测失败: mysql-community-libs(x86-64) >= 5.7.9 被 (已安裝) mysql-community-li
错误: 错误原因:没有删除之前安装的依赖问题 解决办法: yum remove mysql-libs 再用下面指令检查一遍: rpm -qa | grep mysql 如果有还未清理的,用下面指令: rpm -e xxx...
使用MATLAB解算炼油厂的选址
背景 记得有一年的数据建模大赛,试题是炼油厂的选址,最后我们采用MATLAB编写(复制)蒙特卡洛算法,还到了省级一等奖,这里把仅有一些记忆和材料,放到这里来,用来纪念消失的青春。 本…...
AudioTrack播放音乐之getMinBufferSize
1. AudioTrack播放音乐之前需要做好准备,即需要先计算最小音频数据缓存空间 文件路径:AudioTrack.java (frameworks\base\media\java\android\media) static public int getMinBufferSize(int sampleRateInHz, int channelConfig, int audioFormat) {@参数sampleRateInHz,…...
XML Group端口详解
在XML数据映射过程中,经常需要对数据进行分组聚合操作。例如,当处理包含多个物料明细的XML文件时,可能需要将相同物料号的明细归为一组,或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码,增加了开…...
第19节 Node.js Express 框架
Express 是一个为Node.js设计的web开发框架,它基于nodejs平台。 Express 简介 Express是一个简洁而灵活的node.js Web应用框架, 提供了一系列强大特性帮助你创建各种Web应用,和丰富的HTTP工具。 使用Express可以快速地搭建一个完整功能的网站。 Expre…...
Golang 面试经典题:map 的 key 可以是什么类型?哪些不可以?
Golang 面试经典题:map 的 key 可以是什么类型?哪些不可以? 在 Golang 的面试中,map 类型的使用是一个常见的考点,其中对 key 类型的合法性 是一道常被提及的基础却很容易被忽视的问题。本文将带你深入理解 Golang 中…...
中南大学无人机智能体的全面评估!BEDI:用于评估无人机上具身智能体的综合性基准测试
作者:Mingning Guo, Mengwei Wu, Jiarun He, Shaoxian Li, Haifeng Li, Chao Tao单位:中南大学地球科学与信息物理学院论文标题:BEDI: A Comprehensive Benchmark for Evaluating Embodied Agents on UAVs论文链接:https://arxiv.…...
Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility
Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility 1. 实验室环境1.1 实验室环境1.2 小测试 2. The Endor System2.1 部署应用2.2 检查现有策略 3. Cilium 策略实体3.1 创建 allow-all 网络策略3.2 在 Hubble CLI 中验证网络策略源3.3 …...
vue3 字体颜色设置的多种方式
在Vue 3中设置字体颜色可以通过多种方式实现,这取决于你是想在组件内部直接设置,还是在CSS/SCSS/LESS等样式文件中定义。以下是几种常见的方法: 1. 内联样式 你可以直接在模板中使用style绑定来设置字体颜色。 <template><div :s…...
linux 错误码总结
1,错误码的概念与作用 在Linux系统中,错误码是系统调用或库函数在执行失败时返回的特定数值,用于指示具体的错误类型。这些错误码通过全局变量errno来存储和传递,errno由操作系统维护,保存最近一次发生的错误信息。值得注意的是,errno的值在每次系统调用或函数调用失败时…...
如何将联系人从 iPhone 转移到 Android
从 iPhone 换到 Android 手机时,你可能需要保留重要的数据,例如通讯录。好在,将通讯录从 iPhone 转移到 Android 手机非常简单,你可以从本文中学习 6 种可靠的方法,确保随时保持连接,不错过任何信息。 第 1…...
python爬虫:Newspaper3k 的详细使用(好用的新闻网站文章抓取和解析的Python库)
更多内容请见: 爬虫和逆向教程-专栏介绍和目录 文章目录 一、Newspaper3k 概述1.1 Newspaper3k 介绍1.2 主要功能1.3 典型应用场景1.4 安装二、基本用法2.2 提取单篇文章的内容2.2 处理多篇文档三、高级选项3.1 自定义配置3.2 分析文章情感四、实战案例4.1 构建新闻摘要聚合器…...
SpringBoot+uniapp 的 Champion 俱乐部微信小程序设计与实现,论文初版实现
摘要 本论文旨在设计并实现基于 SpringBoot 和 uniapp 的 Champion 俱乐部微信小程序,以满足俱乐部线上活动推广、会员管理、社交互动等需求。通过 SpringBoot 搭建后端服务,提供稳定高效的数据处理与业务逻辑支持;利用 uniapp 实现跨平台前…...
