【教学类-45-06】正确 X-Y之间的三连加减题混合 (竖向排列)(44格:11题“++ ”11题“--”11题“ +-”11题“ -+” )

  作品展示:

b12ebbbcaf68483195679ddfcf810d9b.png

7138ea1db2c74c1d8f1eb1b74fbaab12.png

 

背景需求:

把以下四款3连题 混在一起,每种题目随机抽取11题,一共44格

出现问题:

1、+- 、-+里面有重复题

2、升序排列最好竖排展示

 

素材准备:

acb642ee3fd54711ba1e4b9c66f0929c.png

476a69feb2514aeaaa046f53f059d03e.png

4c5b69ab1dc94d18bf21cec3245382d6.png

b73f7ccd56e24c74b14d347edffeb881.png

 

问题改正

1、单元格修改:确保竖列写入

修改前

008046aa25014ff6b601f8065ca6cb23.png

修改后

078c9899c63d498ba65267cf2c3df2a2.png

2、少了一部分的去重排序

修改前

0021a20db2d14f70af2a49627f7dfe38.png修改后2c5d6502930242f4bed8241c6c9095b2.png

 

 

 

 

 

​代码展示

'''
X-Y 3连加减 单元格竖排 4类题型等比例抽取。44格子每种11题 
1、按比例抽题:44格子每种11题,3、3++ 3-- 3+- 3-+ 比例各2.5


时间:2024年1月10日 10:46
作者:阿夏
'''

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 qn


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

# 第一步:制作不重复所有“+-”、不重复所有减法

# 不重复的数字题
num=int(input('打印几份(必须是双数)\n'))

# int(input('一共几个单元格(55个)\n'))
# classroom=input('班级(输入中、大)\n')
# 本次是2.5浮点数,不是整数
bl=float(input('抽取比例,4类题2.5\n'))
size=20
height1=12
weight1=4

gz=(height1-1)*weight1
sum1=int(input('X-Y以内的“三连题” 最小数字X\n'))
sum2=int(input('X-Y以内的“三连题” 最大数字Y\n'))
l=int(input('输入1,题目打乱,输入2,++ -- +- -+\n'))


# for  sum in [sum2]:
# 5以内“+-”题共21题

P=[]
jiajia=[]
# 3加加
for a in range(0,sum2+1):     # 起始数字就是10,就是排除掉0-10之间的数字
    for b in range(0,sum2+1):      # 起始数字为0,
        for c in range(0,sum2+1):     # 起始数字就是10,就是排除掉0-10之间的数字
            if sum1<=a+b+c<sum2+1 or sum1<=a+c+b<sum2+1 or sum1<=b+a+c<sum2+1 or \
                sum1<=b+c+a<sum2+1 or sum1<=c+a+b<sum2+1 or sum1<=c+b+a<sum2+1 :         
                # print('{}+{}='.format(a,b))
                jiajia.append('{}+{}+{}='.format(a,b,c))
                jiajia.append('{}+{}+{}='.format(a,c,b))
                jiajia.append('{}+{}+{}='.format(b,a,c))
                jiajia.append('{}+{}+{}='.format(b,c,a))
                jiajia.append('{}+{}+{}='.format(c,a,b))
                jiajia.append('{}+{}+{}='.format(c,b,a))
                # 0-5 三连加 56道
                # 0-10 三连加 286道
            else:
                pass
jiajia=list(set(jiajia))  # 加法题 去重 42变成21题
jiajia.sort() # 升序
print(len(jiajia))

# 3减减
jianjian=[]
for a in range(0,sum2+1):     # 起始数字就是10,就是排除掉0-10之间的数字
    for b in range(0,sum2+1):      # 起始数字为0,
        for c in range(0,sum2+1):     # 起始数字就是10,就是排除掉0-10之间的数字
            if sum1<=a-b-c<sum2+1 and a>=b and a>=c:
                jianjian.append('{}-{}-{}='.format(a,b,c))
            if sum1<=a-c-b<sum2+1 and a>=c and a>=b:
                jianjian.append('{}-{}-{}='.format(a,c,b))
            if sum1<=b-a-c<sum2+1 and b>=a and b>=c:
                jianjian.append('{}-{}-{}='.format(b,a,c))
            if sum1<=b-c-a<sum2+1 and b>=c and b>=a:
                jianjian.append('{}-{}-{}='.format(b,c,a))
            if sum1<=c-a-b<sum2+1 and c>=a and c>=b:
                jianjian.append('{}-{}-{}='.format(c,a,b))
            if sum1<=c-b-a<sum2+1 and c>=b and c>=a:         
                jianjian.append('{}-{}-{}='.format(c,b,a))  
                # 0-5 三连减 34道
                # 0-10 三连减 161题   
            else:
                pass 
jianjian=list(set(jianjian)) # 减法题 去重 42变成21题
jianjian.sort() # 升序
print(len(jianjian)) # 21

# 3加减
jiajian=[]
for a in range(0,sum2+1):     # 
    for b in range(0,sum2+1):      # 起始数字为0,
        for c in range(0,sum2+1):     # 
                # 三个数字先加后减最后答案在0-5之间,三个数字本身加起来是0-5之间
            if sum1<=a+b-c<sum2+1 and a+b>=c and sum1<a+b+c<sum2+1:                      
                jiajian.append('{}+{}-{}='.format(a,b,c))
            if sum1<=a+c-b<sum2+1 and a+c>=b and sum1<=a+b+c<sum2+1:   
                jiajian.append('{}+{}-{}='.format(a,c,b))
            if sum1<=b+a-c<sum2+1 and b+a>=c and sum1<=a+b+c<sum2+1:   
                jiajian.append('{}+{}-{}='.format(b,a,c))
            if sum1<=b+c-a<sum2+1 and b+c>=a and sum1<=a+b+c<sum2+1:   
                jiajian.append('{}+{}-{}='.format(b,c,a))
            if sum1<=c+a-b<sum2+1 and c+a>=b and sum1<=a+b+c<sum2+1:   
                jiajian.append('{}+{}-{}='.format(c,a,b))
            if sum1<=c+b-a<sum2+1 and c+b>=a and sum1<=a+b+c<sum2+1:   
                jiajian.append('{}+{}-{}='.format(c,b,a))
                # 0-5 三连加减减 42道
                # 0-10 三连加减减 216道
            else:
                pass
jiajian=list(set(jiajian)) # 减法题 去重 42变成21题
jiajian.sort() # 升序
print(len(jiajian)) # 21


# 3减加
jianjia=[]
for a in range(0,sum2+1):     # 
    for b in range(0,sum2+1):      # 起始数字为0,
        for c in range(0,sum2+1):     # 
                # 三个数字先加后减最后答案在0-5之间,三个数字本身加起来是0-5之间
            # 先减后加,确保第一个数大于第二个数
            if sum1<=a-b+c<sum2+1 and a>=b and sum1<a+b+c<sum2+1:                      
                jianjia.append('{}-{}+{}='.format(a,b,c))
            if sum1<=a-c+b<sum2+1 and a>=c and sum1<=a+b+c<sum2+1:   
                jianjia.append('{}-{}+{}='.format(a,c,b))
            if sum1<=b-a+c<sum2+1 and b>=a and sum1<=a+b+c<sum2+1:   
                jianjia.append('{}-{}+{}='.format(b,a,c))
            if sum1<=b-c+a<sum2+1 and b>=c and sum1<=a+b+c<sum2+1:   
                jianjia.append('{}-{}+{}='.format(b,c,a))
            if sum1<=c-a+b<sum2+1 and c>=a and sum1<=a+b+c<sum2+1:   
                jianjia.append('{}-{}+{}='.format(c,a,b))
            if sum1<=c-b+a<sum2+1 and c>=b and sum1<=a+b+c<sum2+1:   
                jianjia.append('{}-{}+{}='.format(c,b,a))
                # 0-5 三连减加 34道
                # 0-10 三连减加 161道
            else:
                pass
jianjia=list(set(jianjia)) # 减法题 去重 42变成21题
jianjia.sort() # 升序
print(len(jianjia)) # 21


P=len(jianjian)+len(jiajia)+len(jiajian)+len(jianjia)
print(P)# 0-5加法减法题目总数42

L=jiajia+jianjian+jiajian+jianjia
print(L)
print(len(L))
# ['0+0=', '0+1=', '0+2=', '0+3=', '0+4=', '0+5=', '1+0=', '1+1=', '1+2=', '1+3=', '1+4=', '2+0=', '2+1=', '2+2=', '2+3=', '3+0=', '3+1=', '3+2=', '4+0=', '4+1=', '5+0=', '0-0=', '1-0=', '1-1=', '2-0=', '2-1=', '2-2=', '3-0=', '3-1=', '3-2=', '3-3=', '4-0=', '4-1=', '4-2=', '4-3=', '4-4=', '5-0=', '5-1=', '5-2=', '5-3=', '5-4=', '5-5=']






# 第一行的班级和项目
A=[]
# c='{}'.format(classroom)

if P>gz:     # 0-10等于132题,大于55,单元格数量55
    print('数学题总数大于55,实际题目数量{}'.format(gz))
    sl=P
    tl1=int(float(gz*bl*10/100))     # 加法题的题量是 21*50/100  可能是浮点数10.5,所以要用int=10
    # print(tl1)
    tl3=tl2=tl1
    tl4=gz-(tl3+tl2+tl1)
    print(tl4)
    print(tl3)    
    print(tl2)
    print(tl1)
    title='{}-{}“3连题4类”{}抽{}题1/4'.format(sum1,sum2,P,gz)

    
    

if P<=gz:    # 0-5等于42题,小于于55,单元格数量42
    print('数学题总数小于55,实际题目数量{}'.format(P))
    sl=P
    tl1=len(jiajia)    # 加法题的题量是 21*50/100  可能是浮点数10.5,所以要用int=11
    print(tl1)
    tl3=tl2=tl1
    tl4=gz-(tl3+tl2+tl1)
    title='{}-{}“+-”{}抽{}题 全部包含'.format(sum1,sum2,P,P)
    print(tl4)
    print(tl3)


d=['0002']
# 表格0 表格2的 03 05单元格里写入标题信息c
# A.append(c)
A.append(title)
print(A)    

# 制作"单元格"
bgall=[]
for bb in d:
    bgall.append(bb)

for y in range(0,weight1):       # 4
    for x in range(1,height1):     # 12
        s1='{}{}'.format('%02d'%x,'%02d'%y)       # 数字加空格
        bgall.append(s1)   
print(bgall)        
print(len(bgall))

# 不同情况下的单元格数量
if P <=gz:
    bg=bgall[0:2+P]
    print(bg)
    print(len(bg))
else:
    bg=bgall[0:2+gz]
    print(bg)
    print(len(bg))

# ['0003', '0005', '0100', '0101', '0102', '0103', '0104', '0200', '0201', '0202', '0203', '0204', '0300', '0301', '0302', '0303', '0304', '0400', '0401', '0402', '0403', '0404', '0500']




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

D=[]
n=int(num/2)
for z in range(0,n):   #多少份  
    # 标题说明
    
        # 新建word
    doc = Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\加减法\05三连加减一页两份.docx')  
    for j in range(2):
        D.clear()

        if P <=gz:
        # D=[]
        # 小于9的题目,要计算一共有几题,写入等量的单元格内,            
            
            C1=random.sample(jiajia,tl1)  
            for cc1 in C1:
                D.append(cc1)
            C2=random.sample(jianjian,tl2)  
            for cc2 in C2:
                D.append(cc2)
            C3=random.sample(jiajian,tl3)  
            for cc3 in C3:
                D.append(cc3)
            C4=random.sample(jianjia,tl4)  
            for cc4 in C4:
                D.append(cc4)

            if l==1:
                random.shuffle(D)  
            #  如果=1,加减混合打乱
            if l==2:
             #  如果=2,先出加法,再出减法
               pass

            print(D)
            print(len(D))
            
            D.insert(0,title)           # 写入班级,项目名称
            # D.insert(0,classroom) 

        else:
        # D=[]
        # 大于9的题目,只要抽取55题,多余的写不下,
                      
            C1=random.sample(jiajia,tl1)  
            for cc1 in C1:
                D.append(cc1)
            C2=random.sample(jianjian,tl2)  
            for cc2 in C2:
                D.append(cc2) 
            C3=random.sample(jiajian,tl3)  
            for cc3 in C3:
                D.append(cc3) 
            C4=random.sample(jianjia,tl4)  
            for cc4 in C4:
                D.append(cc4)

            if l==1:
                random.shuffle(D)  
            #  如果=1,加减混合打乱
            if l==2:
             #  如果=2,先出加法,再出减法
               pass
           

            print(D)
            print(len(D))

            D.insert(0,title)           # 写入班级,项目名称
            # D.insert(0,classroom) 

    
#       # 房间模板(第一个表格)要写入的门牌号列表 
        table = doc.tables[j]          # 表0,表2 写标题用的
        # 标题写入3、5单元格  
        for t in range(0,len(bg)):             # 0-5是最下面一行,用来写卡片数字
            pp=int(bg[t][0:2])     # 
            qq=int(bg[t][2:4])
            k=str(D[t])              # 提取list图案列表里面每个图形  t=索引数字
            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(size) #是否加粗
            # run.font.color.rgb = RGBColor(150,150,150) #数字小,颜色深0-255
            run.font.color.rgb = RGBColor(150,150,150) #数字小,颜色深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.LEFT #居中   
#    
    doc.save(r'C:\Users\jg2yXRZ\OneDrive\桌面\加减法\零时Word\{}.docx'.format('%02d'%(z+1)))#保存为XX学号的电话号码word     
    time.sleep(2)
    from docx2pdf import convert
    # docx 文件另存为PDF文件
    inputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/加减法/零时Word/{}.docx".format('%02d'%(z+1))# 要转换的文件:已存在
    outputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/加减法/零时Word/{}.pdf".format('%02d'%(z+1))  # 要生成的文件:不存在
    # 先创建 不存在的 文件
    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)

if P <=gz :
    if l==1:        # 打乱
        file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)03“三连题”(一页两份 ){}题{}-{}之间“4类三连题”数量{}比{}比{}比{}乱序(共{}题抽{}题)({}共{}人打印{}张).pdf" .format(gz,'%02d'%sum1,'%02d'%sum2,bl,bl,bl,10-bl*3,'%03d'%P,'%02d'%P,c,num,n))
    else:         # 先加后减
        file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)03“三连题”(一页两份 ){}题{}-{}之间“4类三连题”数量{}比{}比{}比{}顺序(共{}题抽{}题)({}共{}人打印{}张).pdf" .format(gz,'%02d'%sum1,'%02d'%sum2,bl,bl,bl,10-bl*3,'%03d'%P,'%02d'%P,c,num,n))
else:
    if l==1:        # # 打乱
        file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)03“三连题”(一页两份 ){}题{}-{}之间“4类三连题”数量{}比{}比{}比{}乱序(共{}题抽{}题)({}共{}人打印{}张).pdf".format(gz,'%02d'%sum1,'%02d'%sum2,bl,bl,bl,10-bl*3,'%03d'%P,gz,c,num,n))
    else:    # 先加后减
        file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)03“三连题”(一页两份 ){}题{}-{}之间“4类三连题”数量{}比{}比{}比{}顺序(共{}题抽{}题)({}共{}人打印{}张).pdf".format(gz,'%02d'%sum1,'%02d'%sum2,bl,bl,bl,10-bl*3,'%03d'%P,gz,c,num,n))

file_merger.close()
# doc.Close()

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

终端输入

b5434c82f7374ab7a97f6f8ff5c0b18b.png

 

 

结果展示:

1c616ae7aeba43f38637c82c558a7b2e.png

0-5  3连题4类 一共抽取44题,并按照顺序排列(同类题目在一起)

1、++题 11题

2、--题 11题

3、+-题 11题

4、-+题 11题

b12ebbbcaf68483195679ddfcf810d9b.png

​​

0-10  3连题4类 一共抽取44题,并按照顺序排列(同类题目在一起)

1、++题 11题

2、--题 11题

3、+-题 11题

4、-+题 11题

9602e9b5b10941b2868ac5238994f52e.png

第二种:乱序排列

02c0b15b89d441a3b0c153f533748b1f.png

 

 

7138ea1db2c74c1d8f1eb1b74fbaab12.png

005bb8898615499d9248f4f50f382026.png

 

感悟:

生成的数学题一定先老师自己做一下,验证是否正确。,

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/309497.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【elastic search】JAVA操作elastic search

目录 1.环境准备 2.ES JAVA API 3.Spring Boot操作ES 1.环境准备 本文是作者ES系列的第三篇文章&#xff0c;关于ES的核心概念移步&#xff1a; https://bugman.blog.csdn.net/article/details/135342256?spm1001.2014.3001.5502 关于ES的下载安装教程以及基本使用&…

鸿蒙Harmony--状态管理器--@Prop详解

纵横千里独行客&#xff0c;何惧前路雨潇潇。夜半浊酒慰寂寞&#xff0c;天明走马入红尘。且将新火试新茶&#xff0c;诗酒趁年华。青春以末&#xff0c;壮志照旧&#xff0c;生活以悟&#xff0c;前路未明。时间善变&#xff0c;可执着翻不了篇。时光磨我少年心&#xff0c;却…

正则表达式、文件访问(Python实现)

一、主要目的&#xff1a; 1.了解正则表达式的基本概念和处理过程。 2.掌握使用正则表达式模块 Re 进行字符串处理的方法。 3.了解文件的基本概念和类型。 4.掌握在 Python 中访问文本文件的方法和步骤。 5.熟悉在 Python 中访问二进制文件的方法和步骤。 二、主要内容和结…

HelpLook VS Docusaurus:SaaS 知识库软件和 SSG 的对比

在选择文档工具时&#xff0c;需要考虑多个因素&#xff0c;如功能、易用性、成本等。Docusaurus是一个开源工具&#xff0c;它因其灵活性而受到文档团队的青睐&#xff0c;尤其是负责软件产品文档的团队。有些组织甚至可能要求使用开源软件&#xff0c;因此选择一个开源工具如…

读元宇宙改变一切笔记04_网络化

1. 思想实验 1.1. 如果森林中的一棵树倒下&#xff0c;但周围没有人听到&#xff0c;那它是否会发出声音&#xff1f; 1.1.1. “贝克莱的树” 1.2. 主观唯心主义哲学家乔治贝克莱(George Berkeley)提出的&#xff0c;他认为“存在就是被感知” 1.2.1. 如果有人或有其他事物…

CMake入门教程【高级篇】qmake转cmake

&#x1f608;「CSDN主页」&#xff1a;传送门 &#x1f608;「Bilibil首页」&#xff1a;传送门 &#x1f608;「动动你的小手」&#xff1a;点赞&#x1f44d;收藏⭐️评论&#x1f4dd; 文章目录 1. 概述2.qmake与cmake的差异3. qmake示例4.qmake转cmake示例5.MOC、UIC和RCC…

1991-2022年A股上市公司股价崩盘风险指标数据

1991-2022年A股上市公司股价崩盘风险指标数据 1、时间&#xff1a;1991-2022年 2、来源&#xff1a;整理自csmar 3、指标&#xff1a;证券代码、交易年度、NCSKEW(分市场等权平均法)、NCSKEW(分市场流通市值平均法)、NCSKEW(分市场总市值平均法)&#xff1b; NCSKEW(综合市…

网络协议与攻击模拟_03实施ARP欺骗和攻击

一、ARP攻击 1、实验环境 kali Linux &#xff08;安装arpspoof工具&#xff09;被攻击主机 2、kali配置 kali Linux系统是基于debian Linux系统&#xff0c;采用deb包管理方式&#xff0c;可以使用apt源的方式进行直接从源的安装。 配置kali网络源 vim /etc/apt/sources…

本地远程实时获取无人机采集视频图像(天空端 + jetson nano + 检测分割 + 回传地面端显示)

1、无线图传设备介绍 2、jetson nano天空端数据采集检测保存 3、本地回传显示 1、无线图传设备介绍 由于本设计考虑将无人机得到检测结果实时回传给地面站显示&#xff0c;因此需要考虑一个远程无线通信设备进行传输。本设计采用思翼HM30图传设备。通过无线图传的wifi将天空端…

基于JavaWeb+BS架构+SpringBoot+Vue协同过滤算法的体育商品推荐系统的设计和实现

基于JavaWebBS架构SpringBootVue协同过滤算法的体育商品推荐系统的设计和实现 文末获取源码Lun文目录前言主要技术系统设计功能截图订阅经典源码专栏Java项目精品实战案例《500套》 源码获取 文末获取源码 Lun文目录 1 绪 论 1 1.1项目背景 1 1.2研究意义 2 1.3设计目的 2 1.…

【动态规划】C++ 算法458:可怜的小猪

作者推荐 视频算法专题 涉及知识点 动态规划 数学 力扣458:可怜的小猪 有 buckets 桶液体&#xff0c;其中 正好有一桶 含有毒药&#xff0c;其余装的都是水。它们从外观看起来都一样。为了弄清楚哪只水桶含有毒药&#xff0c;你可以喂一些猪喝&#xff0c;通过观察猪是否…

ROS2——开发第一个节点

ROS2 的包必须在 src 文件夹下&#xff0c;使用下面的命令创建一个包&#xff0c;并设置相关的依赖 ros2 pkg create my_package --dependencies rclcpp std_msgs可以打开包内的 package.xml &#xff0c;查看 depend 有哪些依赖 #include "rclcpp/rclcpp.hpp" int …

路由黑洞和黑洞路由的区别

路由黑洞&#xff1a; 路由黑洞是一种现象&#xff0c;一般是在网络边界做汇总回程路由的时候产生的一种不太愿意出现的现象&#xff0c;就是汇总的时候有时会有一些不在内网中存在的网段&#xff0c;但是又包含在汇总后的网段中&#xff0c;如果在这个汇总的边界设备上同时还配…

QML实现的图片浏览器

很久之前实现了一个QWidget版本的图片浏览器:基于Qt5的图片浏览器QHImageViewer 今天用QML也实现一个,功能差不多: ●悬浮工具栏 ●支持图片缩放、旋转、还原、旋转、拖动。 ●拖动图片时,释放鼠标图片会惯性滑动。 ●支持左右翻页查看文件夹中的图片。 ●支持保存图片至本…

03MyBatis完成CRUD+命名空间

准备工作 ○ 创建module&#xff08;Maven的普通Java模块&#xff09;&#xff1a;mybatis-002-crud ○ pom.xml ■ 打包方式jar ■ 依赖&#xff1a; ● mybatis依赖 ● mysql驱动依赖 ● junit依赖 ● logback依赖 ○ mybatis-config.xml放在类的根路径下 ○ CarMapper.xml放…

gem5学习(11):将缓存添加到配置脚本中——Adding cache to the configuration script

目录 一、Creating cache objects 1、Classic caches and Ruby 二、Cache 1、导入SimObject(s) 2、创建L1Cache 3、创建L1Cache子类 4、创建L2Cache 5、L1Cache添加连接函数 6、为L1ICache和L1DCache添加连接函数 7、为L2Cache添加内存侧和CPU侧的连接函数 完整代码…

【书生大模型Demo-2】

书生大模型Demo 1 大模型InternLM介绍2 Demo2.1 InternLM-Chat-7B智能对话Demo2.1.1 环境配置2.1.2 模型下载2.1.3 代码准备2.1.4 运行Demo 2.2 Lagent智能体工具调用Demo2.3 浦语 灵笔图文创作理解Demo 3 作业 实践是最好的老师&#xff1b; 1 大模型InternLM介绍 大模型&…

【占用网络】SurroundOcc:基于环视相机实现3D语义占用预测 ICCV 2023

前言 本文分享“占用网络”方案中&#xff0c;来自ICCV 2023的SurroundOcc&#xff0c;它基于环视相机实现3D语义占用预测。 使用空间交叉注意力将多相机图像信息提升到3D体素特征&#xff0c;即3D体素Query到2D图像中查询融合特征的思想。 然后使用3D卷积逐步对体素特征进行…

Python爬虫---Scrapy项目的创建及运行

Scrapy是一个为了爬取网站数据&#xff0c;提取结构性数据而编写的应用框架。 可以应用在包括数据挖 掘&#xff0c;信息处理或存储历史数据等一系列的程序中。 1. 安装scrapy&#xff1a; pip install scrapy 注意&#xff1a;需要安装在python解释器相同的位置,例如&#xf…

【conda】pip安装报错,网络延时问题解决记录(亲测有效)

【conda】pip安装报错&#xff0c;网络延时问题解决记录 1. pip install 报错如下所示2. 解决方案&#xff1a; 1. pip install 报错如下所示 pip._vendor.urllib3.exceptions.ReadTimeoutError: HTTPSConnectionPool(hostfiles.pythonhosted.org, port443): Read timed out.…