【教学类-46-01】20240130纸尺1.0 (A4横版一条长尺125CM刻度25*5 无图案)

作品展示:

背景需求:

大3班一位孩子用“骰子统计纸”制作了一个身高刻度表

【教学类-40-01】A4骰子纸模制作1.0(飞机形 5.5CM纸盒骰子1个+记录纸1条)(点数是不同的符号图案)-CSDN博客文章浏览阅读160次。【教学类-40-01】A4骰子纸模制作1.0(5.5CM纸盒骰子1个+记录纸1条)(点数是不同的符号图案)https://blog.csdn.net/reasonsummer/article/details/133439421?csdn_share_tail=%7B%22type%22%3A%22blog%22%2C%22rType%22%3A%22article%22%2C%22rId%22%3A%22133439421%22%2C%22source%22%3A%22reasonsummer%22%7D

于是我想用A4纸裁剪N条,黏贴成为一把长尺软尺

素材准备:

尺子的word模板制作相当复杂,各种线条隐藏,合并,填充灰色,o(╥﹏╥)o

代码展示:

'''
目的:
1、1.0纸尺A4 5条
2、作者:阿夏
时间:2024年1月31日)

'''

import os
num=1
# 做一份尺子的模板

jc=25
# 一行最多26
h=5
# 一行0-25 25-50



print('----------第1步:提取数字------------')


# 
all=[]
for z in range(h):

    for i in range(jc*z,jc*(z+1)+1):
        all.append(str(i))   

print(all)
print(len(all))
# 25 50 75 100出现两次 5条一共129CM

# [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 50, 51, 
# 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, 120, 121, 122, 123, 124, 125]

# 分组
list=[]
for l in range(int(len(all)/(jc+1))):
    list.append(all[l*(jc+1):l*(jc+1)+(jc+1)])
print(list)
print(len(list))
               

bg1=[]
for x in range(1,2):
    for y in range(1,(jc+1)*2,2):        # 因为第一行和第二行是斜角错开的,所以格子要翻倍
        # if '%03d'%y=='053':
        #     pass
        # else:
        bg1.append('{}{}'.format('%02d'%x,'%02d'%y))

print(bg1)
print(len(bg1))
# # ['0101', '0103', '0105', '0107', '0109', '0111', '0113', '0115', '0117', '0119', '0121', '0123', '0125', '0127', '0129', '0131', '0133', '0135', '0137', '0139', '0141', '0143', '0145', '0147', '0149']       
# # 25


# # # print('----------第2步:新建一个临时文件夹------------')
# # # # # 新建一个”装N份word和PDF“的文件夹
# os.mkdir
imagePath1=r'C:\Users\jg2yXRZ\OneDrive\桌面\尺子\零时Word'
if not os.path.exists(imagePath1):  # 判断存放图片的文件夹是否存在
    os.makedirs(imagePath1)  # 若图片文件夹不存在就创建

print('----------第2步:制作尺子模板 ------------')

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
import random

import os,time
import docx
from docx import Document
from docx.shared import Inches,Cm,Pt
from docx.shared import RGBColor
from docx.enum.text import WD_PARAGRAPH_ALIGNMENT
from docx.oxml.ns import qn

from docxtpl import DocxTemplate
import pandas as pd
from docx2pdf import convert
from docx.shared import RGBColor


for nn in range(0,num):  # 4

    doc = Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\尺子\尺子.docx')

    for b in range(h):    # 共有2个表格         
        table = doc.tables[b]          # 一共有2个表格
       
        for tt in range(len(bg1)):   # 26个
            pp=int(bg1[tt][0:2])    
            qq=int(bg1[tt][2:4])  
            # print(p)               
            k=str(list[b][tt])            # 每个坐标里面插入一个☉      
            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(46)  #输入字体大小默认30号 换行(一页一份大卡片
            run.font.size = Pt(14) #是否加粗
            run.font.color.rgb = RGBColor(0,0,0) #数字小,颜色深0-255
            run.bold=True
            # paragraph.paragraph_format.line_spacing = Pt(180) #数字段间距
        
            r = run._element
            r.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'%nn))   
    from docx2pdf import convert

    # docx 文件另存为PDF文件
    inputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/尺子/零时Word/{}.docx".format('%02d'%nn)  # 要转换的文件:已存在
    outputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/尺子/零时Word/{}.pdf".format('%02d'%nn)  # 要生成的文件:不存在
    # 先创建 不存在的 文件
    f1 = open(outputFile, 'w')
    f1.close()
    # 再转换往PDF中写入内容
    convert(inputFile, outputFile)

print('----------第4步:把都有PDF合并为一个打印用PDF------------')
    
# 多个PDF合并(CSDN博主「红色小小螃蟹」,https://blog.csdn.net/yangcunbiao/article/details/125248205)
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/桌面/尺子/(打印合集)长尺1.0({}人共{}张).pdf".format(num,int(num)))
file_merger.close()
# doc.Close()



# print('----------第5步:删除临时文件夹------------')    
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/尺子/零时Word') #递归删除文件夹,即:删除非空文件夹o

# 每份插入一个符号(以免搞错)
print('----------第0步:符号------------')

patho=['☆','□','○','◇','△','⊕','☼','☺','☏','◎','⊿','√', '×','☑','☹','☺','☼','♫','❀','❤','✉','✄','✈','♘','♕','♔','☀','☉','☋','☁','☂','☽','♤','♡','♢','♧']

五条剪开,黏贴在一起

后续我还想在5个纸条上加一个图案,以免幼儿操作时搞混

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿夏reasonsummer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值