生成100以内的,3个数的加减法混合技巧运算,带括号

2024-04-08 11:44

本文主要是介绍生成100以内的,3个数的加减法混合技巧运算,带括号,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

生成100以内的,3个数的加减法混合技巧运算,带括号。直接生成word格式,可直接打印

共有3种模式,分别如下

AB-CD+ED        59-43+33                 59-(43-33)=59-10=49

AB-(CD+EB)      77-(59+17)               77-59-17=77-17-59=60-59=1

AB+(CD-EF)      27+(73 - 29)             27+73-29=100-59=41

import os
import sys
import random
import subprocess
import importlib.util
# 全局变量,用于存储导入的模块
global Document, Pt, WD_PARAGRAPH_ALIGNMENT, WD_SECTION_START, WD_ORIENTATIONg_filename = "100以内的技巧运算"
g_num_questions_min = 100   #word格式时,会强制塞满最后一页,所以会等于或大于这个数
g_is_include_result = False #如果改为True,会生成算式和答案
g_blank_lines_num = 4       #行与行之间的空行数,方便在空白处做答
g_one_page_question_num = 3 * 6 #根据这个数来进行换行,每而3列,6行。g_questions = []
def chgWorkDir():curFullPath = os.path.realpath(__file__)curWorkPath, file_name = os.path.split(curFullPath)print(curWorkPath)os.chdir(curWorkPath) print('chgWorkDir to :' + curFullPath)def install_package(package):try:if importlib.util.find_spec(package) == None:print(f"\n\n库 {package} 未安装,正在尝试安装...\n\n")subprocess.check_call([sys.executable, "-m", "pip", "install", package])else:print(f"库 {package} 已安装")except ImportError:print(f"\n\n库 {package} 未安装,正在尝试安装...\n\n")subprocess.check_call([sys.executable, "-m", "pip", "install", package])print(f"库 {package} 安装完成")def init_environment():global Document, Pt, WD_PARAGRAPH_ALIGNMENT, WD_SECTION_START, WD_ORIENTATION# install_package("python-docx")from docx import Documentfrom docx.shared import Ptfrom docx.enum.text import WD_PARAGRAPH_ALIGNMENTfrom docx.enum.section import WD_SECTION_STARTfrom docx.enum.section import WD_ORIENTATION# AB-CD+ED      59-43+33    59-(43-33)=59-10=49
def generate_math_questions_1(num_questions):global g_questionsquestions_count = 0while(1):try:A = random.randint(4, 9)B = random.randint(2, 9)C = random.randint(2, 9)D = random.randint(4, C-1)  # CD > ED, 保证CD大于EDE = random.randint(2, D)X = A*10+BY = C*10+DZ = E*10+Dexpression = f"{X} - {Y} + {Z}"result = X - Y + Z# 检查结果是否小于100if result < 0 or result > 100:continueif B >= D:continueif A == C:continueg_questions.append((expression, result))questions_count += 1if questions_count == num_questions: break;except:continue;return
#AB-(CD+EB)   77-(59+17)      77-59-17=77-17-59=60-59=1
def generate_math_questions_2(num_questions):global g_questionsquestions_count = 0while(1):try:A = random.randint(5, 9)B = random.randint(1, 9)C = random.randint(1, 9)D = random.randint(1, 9)E = random.randint(1, 9)X = A*10+BY = C*10+DZ = E*10+Bexpression = f"{X} - ({Y} + {Z})"result = X - (Y + Z)# 检查结果是否小于100if result <= 10 or result > 100:continueif B + D <= 10:continueg_questions.append((expression, result))questions_count += 1if questions_count == num_questions: break;except:continue;return#AB+(CD-EF)   27+(73 - 29)      27+73-29=100-59=41
def generate_math_questions_3(num_questions):global g_questionsquestions_count = 0while(1):try:A = random.randint(1, 9)B = random.randint(1, 9)C = random.randint(1, 9)D = random.randint(1, 9)E = random.randint(1, 9)F = random.randint(1, 9)X = A*10+BY = C*10+DZ = E*10+Fexpression = f"{X} + ({Y} - {Z})"result = X + (Y - Z)# 检查结果是否小于100if result <= 10 or result > 100:continueif B + D != 10:continueif D == F:continueif Y - 10 <= Z:continueg_questions.append((expression, result))questions_count += 1if questions_count == num_questions: break;except:continue;return
def save_questions_to_txt(questions, filename, question_num, is_include_result = False):filename += ".txt";with open(filename, 'w') as file:for i, q in enumerate(questions, 1):expression, result = qif is_include_result:express = str(i).rjust(2) + f" 、{expression} = {result}\n"else:express = str(i).rjust(2) + f" 、{expression}\n"file.write(express)if (i > question_num - 1):break;def is_near_bottom_margin(doc):for index, para in enumerate(doc.paragraphs):# 获取段落的对齐方式alignment = para.alignment# 检查段落格式是否存在if para.paragraph_format.space_after is not None:# 获取段落的下边距space_after = para.paragraph_format.space_after.pt# 判断对齐方式和下边距位置if alignment == WD_PARAGRAPH_ALIGNMENT.CENTER and space_after > Pt(70):print(f"第{index+1}段落:居中对齐且下边距大于12pt")return Falseelse:print(f"第{index+1}段落:左对齐且下边距小于12pt")return True#如果没有到达页尾,并且超过question_num时,添加空页,则直接返回,表示生成题目数量完成
#如果只是到达页尾,并没有超过question_num,则添加空页
#如果只是到达页中,则添加空行
def add_blank_lines(doc, i, question_num):if i % g_one_page_question_num == 0 and i > 0:if (i >= question_num):return Truedoc.add_page_break()else:for _ in range(g_blank_lines_num - 1):doc.add_paragraph("")return Falsedef save_questions_to_word(questions, filename, question_num, is_include_result = False):filename += ".docx";# 创建一个新的Word文档doc = Document()# 添加g_titile,并设置字体加粗、居中,2号字体content1 = doc.add_paragraph(g_filename)content1.alignment = WD_PARAGRAPH_ALIGNMENT.CENTERcontent1.runs[0].bold = Truecontent1.runs[0].font.size = Pt(20)# 设置第一页的节属性section1 = doc.sections[-1]section1.start_type = WD_SECTION_START.CONTINUOUSsection1.orientation = WD_ORIENTATION.PORTRAITsection1.left_margin = Pt(60) section1.right_margin = section1.left_margin# 添加内容line_context = ""for i, q in enumerate(questions, 1):expression, result = qif is_include_result:express = str(i).rjust(2) + f" 、{expression} = {result}"else:express = str(i).rjust(2) + f" 、{expression}"# 在每个内容之间添加空行if i % 3 == 0:line_context += express;doc.add_paragraph(line_context)line_context = ""if add_blank_lines(doc, i, question_num):break;else:line_context += express + "\t\t\t";if line_context != "":doc.add_paragraph(line_context)# 保存文档doc.save(filename)if __name__ == '__main__':print('生成100以内的,3个数的加减法混合技巧运算,带括号 ...\n')chgWorkDir()init_environment()generate_math_questions_1(g_num_questions_min)generate_math_questions_2(g_num_questions_min)generate_math_questions_3(g_num_questions_min)random.shuffle(g_questions)random.shuffle(g_questions)save_questions_to_txt(g_questions, g_filename, g_num_questions_min, g_is_include_result)save_questions_to_word(g_questions, g_filename, g_num_questions_min, g_is_include_result)

这篇关于生成100以内的,3个数的加减法混合技巧运算,带括号的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/885492

相关文章

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

java中使用POI生成Excel并导出过程

《java中使用POI生成Excel并导出过程》:本文主要介绍java中使用POI生成Excel并导出过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录需求说明及实现方式需求完成通用代码版本1版本2结果展示type参数为atype参数为b总结注:本文章中代码均为

在java中如何将inputStream对象转换为File对象(不生成本地文件)

《在java中如何将inputStream对象转换为File对象(不生成本地文件)》:本文主要介绍在java中如何将inputStream对象转换为File对象(不生成本地文件),具有很好的参考价... 目录需求说明问题解决总结需求说明在后端中通过POI生成Excel文件流,将输出流(outputStre

电脑win32spl.dll文件丢失咋办? win32spl.dll丢失无法连接打印机修复技巧

《电脑win32spl.dll文件丢失咋办?win32spl.dll丢失无法连接打印机修复技巧》电脑突然提示win32spl.dll文件丢失,打印机死活连不上,今天就来给大家详细讲解一下这个问题的解... 不知道大家在使用电脑的时候是否遇到过关于win32spl.dll文件丢失的问题,win32spl.dl

C/C++随机数生成的五种方法

《C/C++随机数生成的五种方法》C++作为一种古老的编程语言,其随机数生成的方法已经经历了多次的变革,早期的C++版本使用的是rand()函数和RAND_MAX常量,这种方法虽然简单,但并不总是提供... 目录C/C++ 随机数生成方法1. 使用 rand() 和 srand()2. 使用 <random

电脑报错cxcore100.dll丢失怎么办? 多种免费修复缺失的cxcore100.dll文件的技巧

《电脑报错cxcore100.dll丢失怎么办?多种免费修复缺失的cxcore100.dll文件的技巧》你是否也遇到过“由于找不到cxcore100.dll,无法继续执行代码,重新安装程序可能会解... 当电脑报错“cxcore100.dll未找到”时,这通常意味着系统无法找到或加载这编程个必要的动态链接库

Flask 验证码自动生成的实现示例

《Flask验证码自动生成的实现示例》本文主要介绍了Flask验证码自动生成的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习... 目录生成图片以及结果处理验证码蓝图html页面展示想必验证码大家都有所了解,但是可以自己定义图片验证码

Python如何在Word中生成多种不同类型的图表

《Python如何在Word中生成多种不同类型的图表》Word文档中插入图表不仅能直观呈现数据,还能提升文档的可读性和专业性,本文将介绍如何使用Python在Word文档中创建和自定义各种图表,需要的... 目录在Word中创建柱形图在Word中创建条形图在Word中创建折线图在Word中创建饼图在Word