python-批量操作excel
-
批量新增excel文件
import osimport xlwings as xwapp = xw.App(visible=True,add_book=False)#visible设置为ture的时候会自动打开创建的excel文件,设为为false的时候不会看到excel文件打开了,实际进程占用了....dept_list = ['人事部','财务部','研发部','行政部']path = os.path.abspath(os.path.abspath(os.path.dirname(__file__)))dept_path = os.path.join(path,'excel文件')for dept in dept_list:workbook = app.books.add()workbook.save(f'{dept_path}/部门业绩-{dept}.xlsx') -
批量打开excel文件
import os import xlwings as xw app = xw.App(visible=True,add_book=False) for dir,curdir,files in os.walk(dept_path):if files:for file in files:file_path = os.path.join(dir,file)if file.endswith('.xlsx'):app.books.open(file_path) -
批量修改excel文件工作表名
import osimport xlwings as xwapp = xw.App(visible=False,add_book=False)path = os.path.abspath(os.path.abspath(os.path.dirname(__file__)))dept_path = os.path.join(path,'excel文件')#批量修改 【部门业绩-行政部.xlsx 】 这个文件的工作表名workbook =app.books.open(f'{dept_path}\部门业绩-行政部.xlsx')for sheet in workbook.sheets:sheet.name = sheet.name.replace('Sheet','部门')workbook.save()app.quit()
4.合并相似excel文件内容到一个excel(只会合并每个excel第一个sheet页的内容)
import pandas as pddata_list = []for dir,curdir,files in os.walk(dept_path):if files:for file in files:file_path = os.path.join(dir,file)if file.endswith('.xlsx') and file.startswith('部门业绩-'):data_list.append(pd.read_excel(file_path))data_all = pd.concat(data_list)data_all.to_excel('部门业绩.xlsx')
-
合并一个excel文件多个sheet页内容到第一个sheet页中
import pandas as pd import xlwings as xw file = f'{dept_path}\部门业绩-行政部.xlsx' df_list = pd.read_excel(file,sheet_name=None) df_all = pd.concat(df_list.values()) app=xw.App(visible=False,add_book=False) workbook = app.books.open(file) workbook.sheets.add('汇总表',before=workbook.sheets[0]) workbook.sheets['汇总表'].range('A1').options(index=False).value=df_all workbook.save() workbook.close() app.quit() -
拆分excel表(按照某个分类拆分成不同的excel表)
import pandas as pd file = f'{dept_path}\产品表.xlsx' df= pd.read_excel(file) products = df['产品类型'].unique() #去重获取产品类型这一列所有产品for product in products:df_product = df[df['产品类型']==product]df_product.to_excel(f'{dept_path}\产品表-{product}.xlsx') -
拆分excel表(按照某个分类拆分成不同的sheet页)
import pandas as pd file = f'{dept_path}\采购表.xlsx' #读取所有sheet页 df_list= pd.read_excel(file,sheet_name=None,parse_dates=False) #合并成一个大数据表 df_all = pd.concat(df_list.values())file2 = f'{dept_path}\采购表-按产品类分.xlsx' excel_writer = pd.ExcelWriter(file2,date_format='YYYY-MM-DD') for product,df in df_all.groupby('产品类型'):df.to_excel(excel_writer,product,index=False) excel_writer.save() -
比较2个excel文件内容
import os import xlwings as xwapp = xw.App(visible=False,add_book=False) file = f'{dept_path}\产品表.xlsx' file_back = f'{dept_path}\产品表-备份.xlsx' book = app.books.open(file) book_backup = app.books.open(file_back)for row in book.sheets[0].range('A1').expand():for cell in row:backup_cell = book_backup.sheets[0].range(cell.address)if cell.value != backup_cell.value:cell.color = backup_cell.color = (255,0,0) book.save() book.close() book_backup.save() book_backup.close() app.quit()
相关文章:
python-批量操作excel
批量新增excel文件 import osimport xlwings as xwapp xw.App(visibleTrue,add_bookFalse)#visible设置为ture的时候会自动打开创建的excel文件,设为为false的时候不会看到excel文件打开了,实际进程占用了....dept_list [人事部,财务部,研发部,行政部…...
#QT(串口助手-界面)
1.IDE:QTCreator 2.实验:编写串口助手 3.记录 接收框:Plain Text Edit 属性选择:Combo Box 发送框:Line Edit 广告:Group Box (1)仿照现有串口助手设计UI界面 (2)此时串口助手大…...
C语言进阶——位段
在C语言中,位段(Bit Fields)是一种用来对结构体中的成员进行位级别的控制的特性。通过位段,我们可以灵活地控制结构体中各个成员的位数,从而节省内存空间并提高程序的效率。本篇博客将详细讲解C语言中位段的相关知识&a…...
软件设计师软考题目解析23 --每日五题
想说的话:要准备软考了。0.0,其实我是不想考的,但是吧,由于本人已经学完所有知识了,只是被学校的课程给锁在那里了,不然早找工作去了。寻思着反正也无聊,就考个证玩玩。 本人github地址…...
总结:前后端集合、数组类型数据交互底层原理,SpringBoot框架解析
总结:前后端集合、数组类型数据交互底层原理,SpringBoot框架解析 一前后端信息交互本质:1.两台电脑可以通过收发电磁波、控制网线电路开关等基础物理设施,就可以进行物理层面的电信号交互,电信号又可以通过各种传感设备…...
2024蓝桥杯每日一题(前缀和)
一、第一题:壁画 解题思路:前缀和贪心枚举 仔细思考可以发现B值最大的情况是一段连续的长度为n/2上取整的序列的累加和 【Python程序代码】 import math T int(input()) for _ in range(1,1T):n int(input())s input()l math.ceil(len(s)/…...
2007-2022年上市公司迪博内部控制评价缺陷数量数据
2007-2022年上市公司迪博内部控制评价缺陷数量数据 1、时间:2007-2022年 2、范围:上市公司 3、指标:证券代码、证券简称、辖区、证监会行业、申万行业、是否存在财报内控重大缺陷、财报内控重大缺陷数量、是否存在财报内控重要缺陷、财报内…...
JAVA虚拟机实战篇之内存调优[4](内存溢出问题案例)
文章目录 版权声明修复问题内存溢出问题分类 分页查询文章接口的内存溢出问题背景解决思路问题根源解决思路 Mybatis导致的内存溢出问题背景问题根源解决思路 导出大文件内存溢出问题背景问题根源解决思路 ThreadLocal占用大量内存问题背景问题根源解决思路 文章内容审核接口的…...
qt自定义时间选择控件窗口
效果如图: 布局如图: 参考代码: //DateTimeSelectWidget #ifndef DATETIMESELECTWIDGET_H #define DATETIMESELECTWIDGET_H#include <QWidget> #include <QDateTime>namespace Ui { class DateTimeSelectWidget; }class DateTim…...
如何不解压直接读取gzip文件里面的文件
要在服务器上不解压缩的情况下读取gzip文件中的文件内容,您可以使用类似于zlib模块的库,这些库允许您在内存中对gzip数据进行操作而无需解压缩到磁盘上的文件。 在Python中,您可以使用gzip模块来实现这一目的。以下是一个示例代码࿰…...
python 截取字符串string.split
目录 作用语法只要第一个值获得第3个值遍历 作用 根据某个符号对数据进行截取 从而获得自己想要的内容 语法 使用’string.split’ 方法 对字符串’123/abc/BPYC’ 以 ‘/’ 进行截取 string "123/abc/BPYC" substring string.split("/") print(subs…...
SpringBoot+Vue实现el-table表头筛选排序(附源码)
👨💻作者简介:在笑大学牲 🎟️个人主页:无所谓^_^ ps:点赞是免费的,却可以让写博客的作者开心好几天😎 前言 后台系统对table组件的需求是最常见的,不过element-ui的el…...
Linux学习之线程
目录 线程概念 1.什么是线程? 2.线程的优缺点 3.线程异常 4.线程用途 线程操作 1.如何给线程传参 2.线程终止 3.获取返回值 4.分离状态 5.退出线程 线程的用户级地址空间: 线程的局部存储 线程的同步与互斥 互斥量mutex 数据不一致的主要过…...
【JavaEE初阶】 JVM类加载简介
文章目录 🍃前言🌲类加载过程🚩加载🚩验证🚩准备🚩解析🚩初始化 🎄双亲委派模型🚩什么是双亲委派模型?🚩双亲委派模型的优点 ⭕总结 🍃…...
.NET Core依赖注入(IoC)不使用构造函数实现注入
在.NET Core中,依赖注入(IoC)通常是通过构造函数注入来实现的,这是推荐的方式,因为它使得依赖关系更加明确和可测试。但是,如果你不想或不能使用构造函数注入,你可以考虑使用方法注入࿰…...
WinSCP下载安装并结合内网穿透实现固定公网TCP地址访问本地服务器
文章目录 1. 简介2. 软件下载安装:3. SSH链接服务器4. WinSCP使用公网TCP地址链接本地服务器5. WinSCP使用固定公网TCP地址访问服务器 1. 简介 Winscp是一个支持SSH(Secure SHell)的可视化SCP(Secure Copy)文件传输软件,它的主要功能是在本地与远程计…...
内联函数|auto关键字|范围for的语法|指针空值
文章目录 一、内联函数1.1概念1.2特性 二、auto关键字2.2类型别名思考2.3auto简介2.4auto使用细则2.4 auto不能推导的场景 三、基于范围的for循环(C11)3.1 范围for的语法 四、指针空值nullptr(C11)4.1 C98中的指针空值 所属专栏:C初阶 一、内联函数 1.1概念 以inline修饰的函…...
家用洗地机哪个型号好用?介绍几个值得考虑的品牌
作为家里的主要清洁工,我一直以来都是负责家里的清洁工作。我经常使用吸尘器和扫地机器人来轮流清洁,虽然效果还不错,但是这种方式太费时间和精力了。特别是在脸上厨房里做完饭和孩子吃完饭后留下的残渣时,我总是需要用传统的拖多…...
力扣-数组题
1. 两数之和 找出map中是否有target-nums[i], class Solution { public:vector<int> twoSum(vector<int>& nums, int target) {unordered_map<int, int> hash;for(int i 0 ;i < nums.size(); i){if(hash.find(target - nums[i]) ! hash…...
将List转换为数组或者将数组转换为List,如果改变了原始值,转换后的数据会发生改变吗?
将List转换为数组或将数组转换为List涉及到数据结构的变化。在Java中,这两种转换是否会影响原始数据取决于转换的方式和使用的数据结构。下面分别解释这两种情况: 将List转换为数组 当你将一个List转换为数组时,通常通过List的toArray()方法…...
HEPTv2:基于LSH与Transformer的高效粒子轨迹重建
1. 项目概述:HEPTv2的诞生背景与技术定位在粒子物理实验领域,带电粒子轨迹重建一直是个令人头疼的计算难题。想象一下,当质子束在大型强子对撞机(LHC)中以接近光速对撞时,每次碰撞会产生数百个带电粒子&…...
保姆级教程:从零开始用MetaWRAP处理肠道宏基因组数据(含完整代码与避坑指南)
肠道宏基因组分析实战:MetaWRAP全流程解析与深度优化指南 第一次接触宏基因组数据分析时,我被淹没在各类工具的参数海洋中——直到发现MetaWRAP这个"瑞士军刀"。不同于其他需要手动拼接流程的工具,它用模块化设计将质控、组装、分箱…...
别再死记硬背了!用Fastjson 1.2.62处理JSON,这3个真实业务场景你肯定遇到过
Fastjson实战:3个高频业务场景深度解析 每次看到同事在手动拼接JSON字符串,或者用反射处理复杂嵌套结构时,我都忍不住想分享Fastjson这个利器。作为阿里巴巴开源的JSON处理库,Fastjson在性能上一直保持着领先优势,特别…...
利用systemd定时器实现Ubuntu服务精准延迟启动
1. 为什么需要精准延迟启动服务? 在Ubuntu服务器管理中,经常会遇到这样的场景:某个关键服务启动得太早,结果因为依赖项没准备好而频繁报错。比如数据库服务需要等存储设备挂载完成,或者Web应用需要等数据库服务就绪。传…...
【WRF-DART第2.5期】准备观测数据 (Prepare observations)
目录 1. 教程捷径 vs. 实际应用 2. DART 观测处理的核心概念 3. 核心实操:PREPBUFR 数据的两阶段转换流程 Step3.1-下载原始数据并解压 Step3.2-安装文本转换工具 Step3.3-执行数据转换 4. 官方建议与替代方案 (Hint) 参考 在数据同化(Data Assimilation)中,模型需要摄入真…...
别再死记硬背论文了!用Python+Transformer复现医学报告生成SOTA模型(附代码)
用PythonTransformer实战医学报告生成:从论文到SOTA模型的完整复现指南 当你在PubMed或arXiv上读到那些指标惊艳的医学报告生成论文时,是否曾被复杂的模型架构图劝退?本文将以第三篇论文《Radiology Report Generation with General and Spec…...
终极指南:3步掌握N_m3u8DL-RE的流媒体下载魔法
终极指南:3步掌握N_m3u8DL-RE的流媒体下载魔法 【免费下载链接】N_m3u8DL-RE Cross-Platform, modern and powerful stream downloader for MPD/M3U8/ISM. English/简体中文/繁體中文. 项目地址: https://gitcode.com/GitHub_Trending/nm3/N_m3u8DL-RE 你是…...
这篇带你彻底拿捏Redis数据结构 !
Redis 为什么那么快?除了它是内存数据库,使得所有的操作都在内存上进行之外,还有一个重要因素,它实现的数据结构,使得我们对数据进行增删查改操作时,Redis 能高效的处理。因此,这次我们就来好好…...
终极指南:3步快速部署MoneyPrinterPlus AI短视频自动生成工具
终极指南:3步快速部署MoneyPrinterPlus AI短视频自动生成工具 【免费下载链接】MoneyPrinterPlus AI一键批量生成各类短视频,自动批量混剪短视频,自动把视频发布到抖音,快手,小红书,视频号上,赚钱从来没有这么容易过! 支持本地语音模型chatTTS,fasterwhisper,GPTSoV…...
3步搭建NAS媒体库自动化管理系统:MoviePilot完整指南
3步搭建NAS媒体库自动化管理系统:MoviePilot完整指南 【免费下载链接】MoviePilot NAS媒体库自动化管理工具 项目地址: https://gitcode.com/gh_mirrors/mo/MoviePilot 在数字媒体时代,如何高效管理海量的电影和电视剧资源成为许多NAS用户的痛点。…...
