【python VS vba(系列2)】 python和vba读写EXCEL文件的方式比较 (建设ing)

目录

1   用VBA读写EXCEL文件

1.1 用VBA读写,本工作簿workbook里的特定sheet的特定内容

1.1.1 EXCEL表内内容访问

1.1.2 注意点

1.1.3 代码

1.2 用VBA读写本工作簿workbook里的所有sheet的内容

1.2.1 麻烦之处

1.2.2 方法,如何指定EXCEL里的内容范围

1.2.3 写入内容

1.3 尝试用VBA处理非本workbook,且未打开的情况

2 用python 读写EXCEL文件


1   用VBA读写EXCEL文件

1.1 用VBA读写,本工作簿workbook里的特定sheet的特定内容

  • VBA对单个sheet处理
  • 特殊点:
  1. 处理本EXCEL文件,因为开着VBE,VBA属于本文件,所以本EXCEL表比然是打开的
  2. 对应语法用的也是 thisworkbook.worksheets() ,若不指定缺省也会如此默认

1.1.1 EXCEL表内内容访问

  • 具体到内部,因为EXCEL天生是表格,是数组,是2维数组等
  • 需要使用下面这些对象的层级
  1. sheet.cells()
  2. sheet.range()
  3. sheet.rows() 
  4. 。。。

1.1.2 注意点

  • 注意用于保存workbook, worksheet的变量
  1. 必须先定义为对象
  2. 且用set赋值
  • 比如   
  • Dim path1 As Object (或者worksheet)
  •  Set path1 = ThisWorkbook.Worksheets("now")

1.1.3 代码

'VBA对单个sheet处理
'特殊点:处理本EXCEL文件,因为开着VBE,VBA属于本文件,所以本EXCEL表比然是打开的
Sub print2001()Dim path1 As ObjectSet path1 = ThisWorkbook.Worksheets("now")'读指定sheet里特定内容Debug.Print path1.Cells(1, 1)'往wb的指定sheet写入内容'查下path1当前最大行maxr = path1.Cells(9999, 1).End(xlUp).Rowpath1.Cells(maxr + 1, 1) = 100path1.Cells(maxr + 1, 2) = 101path1.Cells(maxr + 1, 3) = 102path1.Cells(maxr + 1, 4) = 103End Sub

1.2 用VBA读写本工作簿workbook里的所有sheet的内容

  • 目标是遍历这个,整个thisworkbook里面的内容
  • '注意VBA里数组语法的 1 to 4 和1,4完全不同,后者是2维数组

1.2.1 麻烦之处

  • '处理EXCEL的内容会比一般文件麻烦,因为EXCEL天生是表格,是数组,是2维数组等
  • 'VBA处理一个wb里的多个sheet处理,同样使用循环
  1. 注意正确的是 for sheet in workbook.worksheets
  2. 注意是 for sheet in workbook.worksheet  或 for sheet in workbook是错误的

1.2.2 方法,如何指定EXCEL里的内容范围

  • 1 指定要读写的范围边界,写入数组,然后操作数组
  • 2 使用 sheet.usedrange() 作为数组的数据源

1.2.3 写入内容

  • 遍历 sheet,然后写入即可
'注意VBA里数组的1to4 和1,4完全不同,后者是2维数组
'VBA处理一个wb里的多个sheet处理
Sub print2002()Dim path1 As ObjectDim wb As ObjectDim sht As ObjectFor Each sht In ThisWorkbook.WorksheetsDebug.Print "sheetName=" & sht.Namemaxr = sht.Cells(9999, 1).End(xlUp).Rowmaxl = sht.Cells(1, 9999).End(xlToLeft).ColumnDebug.Print "现有内容的最大行数=" & maxrDebug.Print "现有内容的最大列数=" & maxl'因为表很大,数据散布在全表的不同格子里,尝查找限定范围内的内容'显示指定区域的内容arr1 = sht.Range("a1:d10")For i = LBound(arr1, 1) To UBound(arr1, 1)For j = LBound(arr1, 2) To UBound(arr1, 2)Debug.Print arr1(i, j),NextDebug.PrintNext'显示表里用过的内容arr2 = sht.UsedRangeFor i = LBound(arr2, 1) To UBound(arr2, 1)For j = LBound(arr2, 2) To UBound(arr2, 2)Debug.Print arr2(i, j),NextDebug.PrintNextNext'这里写入'往wb的指定sheet写入内容,还是先只追加1行'查下path1当前最大行For Each sht In ThisWorkbook.WorksheetsFor k = 1 To 4sht.Cells(maxr + 1, k) = 99 * kNextNextEnd Sub

1.3 尝试用VBA处理非本workbook,且未打开的情况

2 用python 读写EXCEL文件

需要加载专门的模块---也就是前人造好的轮子,比如这2个:

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【珠峰 WEB 前端架构师课程】学习笔记 100 篇(完结)

该课程是珠峰姜文老师讲的,个人觉得讲的很不错,一路在 b 站学习下来做了 100 篇的学习笔记,收获颇丰。 该课程主要讲了高阶函数、函数柯里化、发布订阅模式、观察者模式、从 0 到 1 实现一个 promise,co 库的实现、eventloop 执行…

apk反编译修改教程系列-----任意修改apk版本号 版本名 防止自动更新【二】

往期教程 apk反编译修改教程系列-----修改apk应用名称 任意修改名称 签名【一】 上期演示了下如何修改apk的名称。相信只要用心的友友都会操作了。这次讲解下如何修改软件的版本号与版本名字的操作 名词浅释: 在apk反编译中的VersionCode---是版本号的意思.是一…

Vue3 实现页面简单的CRUD

请求拦截器 import axios from axios; import { ElNotification, ElMessageBox, ElMessage, ElLoading } from element-plus; import { saveAs } from file-saver; import store from /store; import { getToken } from /utils/token; import errorCode from /utils/errorCode…

基于斑点鬣狗算法的无人机航迹规划-附代码

基于斑点鬣狗算法的无人机航迹规划 文章目录 基于斑点鬣狗算法的无人机航迹规划1.斑点鬣狗搜索算法2.无人机飞行环境建模3.无人机航迹规划建模4.实验结果4.1地图创建4.2 航迹规划 5.参考文献6.Matlab代码 摘要:本文主要介绍利用斑点鬣狗算法来优化无人机航迹规划。 …

LuatOS-SOC接口文档(air780E)-- ioqueue - io序列操作

ioqueue.init(hwtimer_id,cmd_cnt,repeat_cnt) 初始化一个io操作队列 参数 传入值类型 解释 int 硬件定时器id,默认用0,根据实际MCU确定,air105为0~5,与pwm共用,同一个通道号不能同时为pwm和ioqueue int 一个完…

Java 基础 面试 多线程

1.多线程 1.1 线程(Thread) 线程时一个程序内部的一条执行流程,java的main方法就是由一条默认的主线程执行 1.2 多线程 多线程是指从软硬件上实现的多条执行流程的技术(多条线程由CPU负责调度执行) 许多平台都离不开多…

【Matlab笔记_17】查找数组中相同元素

案例一:找到数组中相同元素所在位置索引 方法:使用unique函数用于找到唯一的元素和它们在原数组中的索引。然后,histc函数用于计算每个唯一元素的出现次数,并通过ismember函数找到重复元素在原数组中的索引。最后,通过…

动手学深度学习—网络中的网络NiN(代码详解)

目录 1. NiN块2. NiN模型3. 训练模型 LeNet、AlexNet和VGG都有一个共同的设计模式: 通过一系列的卷积层与汇聚层来提取空间结构特征;然后通过全连接层对特征的表征进行处理。 如果在过程的早期使用全连接层,可能会完全放弃表征的空间结构。 …

Day 1 Vue 页面框架

现在前端框架越来越像后端了,特别是TypeScript这样的语言出现后,开发前端的体验跟后端渐渐接近了。当然,作为一个后端,直接上手前端,还是有很多坑要填的。 本次开发,前端页面框架直接选择Vue。原因很简单&…

深入浅出排序算法之归并排序

目录 1. 归并排序的原理 1.1 二路归并排序执行流程 2. 代码分析 2.1 代码设计 3. 性能分析 4. 非递归版本 1. 归并排序的原理 “归并”一词的中文含义就是合并、并入的意思,而在数据结构中的定义是将两个或者两个以上的有序表组合成一个新的有序表。 归并排序…

Python-pptx教程之一从零开始生成PPT文件

简介 python-pptx是一个用于创建、读取和更新PowerPoint(.pptx)文件的python库。 典型的用途是根据动态内容(如数据库查询、分析数据等),将这些内容自动化生成PowerPoint演示文稿,将数据可视化&#xff0c…

hutool 工具类提高编码效率

hutool 工具类 hutool 依赖 引入 hutool 依赖包。 <dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.8.6</version> </dependency>StrUtil 常用方法&#xff1a; StrUtil.equals&…

【IDEA配置】IDEA配置

参考视频&#xff1a;【idea必知必会】优化设置 告别卡顿 1. 显示内存 右击底下空白区域&#xff0c;出现memory indicator内存指示器&#xff0c;点击勾选即可显示。有的是在Settings->Appearance->Window Options里&#xff0c;如图所示&#xff1a; 2. 内存设置 …

虚拟世界游戏定制开发:创造独一无二的虚拟体验

在游戏开发领域&#xff0c;虚拟世界游戏定制开发是一项引人注目的任务&#xff0c;旨在满足客户独特的需求和愿景&#xff0c;创造一个完全个性化的虚拟世界游戏。这种类型的游戏开发需要专业的技能、深刻的游戏开发知识和密切的与客户合作&#xff0c;以确保游戏满足客户的期…

数据库Redis(二):基本数据类型

Redis中采用Key-Value键值对的形式将数据存储在数据库中&#xff0c;首先介绍Redis中针对键Key的操作命名。 Redis键Key相关命令 # 查看当前库所有key keys * # 判断某个key是否存在 exists <key> # 查看你的key是什么类型 type <key> # 删除指定的key数据 …

uboot移植之环境变量bootargs

一. 简介 uboot 中有两个非常重要的环境变量 bootcmd 和 bootargs。本文来学习 uboot的环境变量 bootargs。 bootargs 环境变量也叫命令行参数。bootargs 保存着 uboot 传递给 Linux 内核的参数。 二. uboot移植之环境变量bootargs 环境变量 bootargs 的设置是在 mx6ull_al…

CI2454 2.4g无线MCU芯片应用

Ci2454集成MCU芯片 | Ci2454是一款集成无线收发器和 8 位 RISC&#xff08;精简指令集&#xff09;MCU 的SOC芯片。 #Ci2454芯片 集成MCU芯片# 中国芯片# 无线收发器特性&#xff1a; 工作在 2.4GHz ISM 频段 调制方式&#xff1a;GFSK/FSK 数据速率&#xff1a;2Mbps/1Mbps…

数据库基础(一)【MySQL】

文章目录 安装 MySQL修改密码连接和退出数据库服务器使用 systemctl 管理服务器进程配置数据库从文件角度看待数据库查看连接情况 安装 MySQL 这是在 Linux 中安装 MySQL 的教程&#xff1a;Linux 下 MySQL 安装。本系列测试用的 MySQL 版本是 5.7&#xff0c;机器是 centOS7.…

LabVIEW中将枚举与条件结构一起使用

LabVIEW中将枚举与条件结构一起使用 枚举是一个具有相应数值的字符串标签型列表。在LabVIEW&#xff08;U8 &#xff0c; U16-默认值和U32&#xff09;中以无符号整数形式应用。 例如&#xff0c;可以有一个枚举保存四个季节&#xff0c;在这种情况下&#xff0c;每个字符串都…

Go之流程控制大全: 细节、示例与最佳实践

引言 在计算机编程中&#xff0c;流程控制是核心的组成部分&#xff0c;它决定了程序应该如何根据给定的情况执行或决策。以下是Go语言所支持的流程控制结构的简要概览&#xff1a; 流程控制类型代码if-else条件分支if condition { } else { }for循环for initialization; con…