Excel百“练“成钢,从题库随机抽取题目 V 2.0版本

Excel,百“练”成钢,神器

最近在学习excel,突发奇想给自己找些题库练练

代码很简单,需要的人不可以直接复制代码,因为文件路径不一样

主要功能就是每天给自己生成自己想练习的题目数量,然后直接生成文件

重新上传了V2.0版本的代码

1.增加了可以循环写入的函数
2.Excel有两种后缀,改进了判断后缀名称写入

需要Excel题库的可以私信联系我

效果图:
在这里插入图片描述

↓↓↓老规矩,废话不多说,代码注释很详细↓↓↓
import datetime
import random
import time
import os

# 定义一个判断在写入时是否有同名文件存在,有的话,就+1,反复调用
def exists():
    global i
    if os.path.isfile(f'D:\\{today}练习{i + 1}.xlsx'):
        i += 1
        exists()
    elif os.path.isfile(f'D:\\{today}练习{i + 1}.xls'):
        i += 1
        exists()
    else:
        write()

# 定义一个写入函数,因为源文件名称有两种后缀,所以,分情况写入
def write():
    global choice
    if choice.endswith('.xlsx'):
        with open(f'D:\\{today}练习{i + 1}.xlsx', 'wb')as f2:
            f2.write(result)
            f2.flush()
    elif choice.endswith('.xls'):
        with open(f'D:\\{today}练习{i + 1}.xls', 'wb')as f2:
            f2.write(result)
            f2.flush()

# 获取今天的时间并格式化输出
today = datetime.datetime.today().strftime('%Y-%m-%d')

# 使用os模块列出题库列表
ku_list = os.listdir(r'D:\Excel训练库')  # 题库路径

# 循环5次,需要几套题,在这里改数字
for i in range(5):
    # 随机选择题库列表中的一个文件
    choice = random.choice(ku_list)
    print(choice)  # 这里可以选择不打印,主要看选中了哪个文件
    # 使用二进制读取选中的文件
    with open(f'D:\Excel训练库\\{choice}', 'rb')as fp:
        result = fp.read()
    time.sleep(0.4)  # 这里可以选择不打印,没什么太大作用
    exists()
private void Save2Excel() { //string file = "F:\\11\\ck.xlsx"; //string path = "F:\\11\\excel\\"; string time = DateTime.Now.ToString("yyyyMMdd"); string file = System.Windows.Forms.Application.StartupPath + "\\ck.xlsx"; string path = System.Windows.Forms.Application.StartupPath + "\\excel\\"; if (!Directory.Exists(path)) { Directory.CreateDirectory(path); } string saveName1 = path + "_" + DateTime.Now.ToString("yyyyMMddHHmmss") + ".xlsx"; excel = new CCExcel(file,saveName1); excel.Exceldata(); } private void textBox1_TextChanged(object sender, EventArgs e) { Form1.name = textBox1.Text.ToString(); } private void Form1_Load(object sender, EventArgs e) { comboBox1.Text = 11.ToString(); comboBox2.Text = 100.ToString(); } private void comboBox1_SelectedIndexChanged(object sender, EventArgs e) { Form1.comB1 = comboBox1.Text.ToString(); } private void comboBox2_SelectedIndexChanged(object sender, EventArgs e) { Form1.comB2 = comboBox2.Text.ToString(); } } public class CCExcel { public Excel.Application appExcel; public Excel.Workbooks wbs; public Excel.Workbook wb; public Excel.Worksheets wss; public Excel.Worksheet ws; private string fileName; private string saveName; public CCExcel(string fileName,string saveName) { // //TODO: 在此处添加构造函数逻辑 // this.fileName = fileName; this.saveName = saveName; } public void Exceldata() { Create(); //Open(fileName); Data2Excel(); Save(saveName); //Save(wb,saveName); //appExcel.ActiveWorkbook.SaveCopyAs(fileName); //判断当前激活的表,并保存这个表。否则,保存时会弹出“是否保存Sheet1.xlsx”的对话框 wb.Close(Type.Missing, Type.Missing, Type.Missing); wbs.Close(); appExcel.Quit(); wb = null; wbs = null; appExcel = null; GC.Collect(); } private void Create()//创建一个Excel对象 { appExcel = new Excel.Application(); wbs = appExcel.Workbooks; wb = wbs.Add(true); //ws = (Excel.Worksheet)wb.ActiveSheet;//这是一个只读sheets集合 //Excel.Worksheet worksheet = wb.ActiveSheet as Excel.Worksheet;//这也是一个只读sheets集合 //Excel.Worksheet ws = (Worksheet)wb.Worksheets[1];//创建工作页sheet单页 ws = wb.Worksheets[1] as Worksheet; //第一个sheet页 ws.Name = "ck"; //这里修改sheet名称 } public void Open(string fileName) { appExcel = new Excel.Application(); wbs = appExcel.Workbooks; wb = wbs.Add(fileName); wb = wbs.Open(fileName,Type.Missing,Type.Missing,Type.Missing,Type.Missing, Type.Missing,Type.Missing,Type.Missing,Type.Missing,Type.Missing, Type.Missing,Type.Missing,Type.Missing,Type.Missing,Type.Missing); }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值