【python脚本】课表信息生成 course_test(源代码)

2024-04-20 00:52

本文主要是介绍【python脚本】课表信息生成 course_test(源代码),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在处理excel表格数据中编写的一个可以自动处理课表信息的脚本。

import os
import openpyxl
import re# 检查文件是否存在
file_name = "course_info.xlsx"
if os.path.exists(file_name):# 如果文件存在,先删除os.remove(file_name)# 创建一个新的 Excel 工作簿
workbook = openpyxl.Workbook()
sheet = workbook.active
# 写入表头
sheet.append(["序号", "课程名称", "周次", "星期", "节次", "上课地点", "任课老师"])
# 保存 Excel 文件
workbook.save(file_name)def append_data_to_excel(excel, new_data):# 打开已存在的 Excel 文件workbook = openpyxl.load_workbook(excel)# 选择要添加数据的工作表,这里假设工作表的名字是 "Sheet"sheet = workbook["Sheet"]# 准备要添加的新数据,例如一个列表# new_data = [num, CourseName, week, day, lesson, classroom, teacher]# 在工作表中添加新数据sheet.append(new_data)# 保存修改后的 Excel 文件workbook.save(excel)# workbook = xlrd.open_workbook('./文献检测情况汇总(持续更新).xlsx')
workbook = openpyxl.load_workbook('./课表数据.xlsx')
work_sheet = workbook['data']num = 0  # 初始化序号for row in work_sheet.iter_rows(values_only=True, min_row=2,):CourseName = row[2];CoureseTimeAddress = row[25];# print(CourseName,CoureseTimeAddress)try:message = CoureseTimeAddress.split(';')# print(message)except:# print("no message")continuefor m in message:if m == '':continuem = m.split()# print(m)week = m[0]day = m[1][:3]# 使用正则表达式提取方括号内的内容pattern = r'\[(.*?)\]'  # 匹配方括号内的任意字符,非贪婪模式matches = re.findall(pattern, m[1])lesson = matches[0]# print(lesson)# 使用正则表达式提取 "1-204" 模式pattern = r'\b\d+-\d+\b'  # 匹配数字-数字模式的单词边界matches = re.findall(pattern, m[1])classroom = matches[0]# print(classroom)teacher = m[2]# num = num + 1# print(num, CourseName, week, day, lesson, classroom, teacher)week = week.split(",")# print(week)for w in week:flag = 0if '单' in w:flag = 1if '周' not in w:w = w[:-1]else:w = w[:-2]elif '双' in w:flag = 2if '周' not in w:w = w[:-1]else:w = w[:-2]else:flag = 0if '周' in w:w = w[:-1]# print(w)if '-' in w:a, b = w.split('-')try:a, b = int(a), int(b)except:print("error")print(a,b)for i in range(a,b+1):if flag==1 and i%2==0:continueif flag==2 and i%2!=0:continuenum = num + 1new_data = [num, CourseName, i, day, lesson, classroom, teacher]print(num, CourseName, i, day, lesson, classroom, teacher)# 将数据存入excel表格append_data_to_excel("course_info.xlsx", new_data)else:num = num + 1w = int(w)new_data = [num, CourseName, w, day, lesson, classroom, teacher]print(num, CourseName, w, day, lesson, classroom, teacher)# 将数据存入excel表格append_data_to_excel("course_info.xlsx", new_data)

这篇关于【python脚本】课表信息生成 course_test(源代码)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python将博客内容html导出为Markdown格式

《Python将博客内容html导出为Markdown格式》Python将博客内容html导出为Markdown格式,通过博客url地址抓取文章,分析并提取出文章标题和内容,将内容构建成html,再转... 目录一、为什么要搞?二、准备如何搞?三、说搞咱就搞!抓取文章提取内容构建html转存markdown

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

微信公众号脚本-获取热搜自动新建草稿并发布文章

《微信公众号脚本-获取热搜自动新建草稿并发布文章》本来想写一个自动化发布微信公众号的小绿书的脚本,但是微信公众号官网没有小绿书的接口,那就写一个获取热搜微信普通文章的脚本吧,:本文主要介绍微信公众... 目录介绍思路前期准备环境要求获取接口token获取热搜获取热搜数据下载热搜图片给图片加上标题文字上传图片

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

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

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

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

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

Python Websockets库的使用指南

《PythonWebsockets库的使用指南》pythonwebsockets库是一个用于创建WebSocket服务器和客户端的Python库,它提供了一种简单的方式来实现实时通信,支持异步和同步... 目录一、WebSocket 简介二、python 的 websockets 库安装三、完整代码示例1.

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

Python使用自带的base64库进行base64编码和解码

《Python使用自带的base64库进行base64编码和解码》在Python中,处理数据的编码和解码是数据传输和存储中非常普遍的需求,其中,Base64是一种常用的编码方案,本文我将详细介绍如何使... 目录引言使用python的base64库进行编码和解码编码函数解码函数Base64编码的应用场景注意