EXCEL-VB编程实现自动抓取多工作簿多工作表中的单元格数据

news/2024/7/21 7:37:35 标签: excel

一、VB编程基础

1、 EXCEL文件启动宏设置

文件-选项-信任中心-信任中心设置-宏设置-启用所有宏

汇总文件保存必须以宏启动工作簿格式类型进行保存

2、 VB编程界面与入门

参考收藏
https://blog.csdn.net/O_MMMM_O/article/details/107260402?spm=1001.2014.3001.5506

二、自动抓取多工作簿多工作表中的单元格数据

1、描述

在同一路径下,有5个EXCEL工作簿,每个工作簿里面有7张工作表sheet,每张sheet里面的固定单元格有同一类型数据;1个EXCEL汇总工作簿,里面有1张工作表sheet,用来汇总抓取的数据内容。
在这里插入图片描述
在这里插入图片描述

2、VB程序

Sub output()
 Application.ScreenUpdating = False
 Dim Mydir As String
 Dim i As Integer
 i = 2
'获取当前工作簿所在路径'
 Mydir = ThisWorkbook.Path & "\"
  'Left(App.Path, 1)是用来返回路径中第一个字母,即盘符 如:C,D,E,chdrive则是改变当前盘'
 ChDrive Left(Mydir, 1)
 
 ChDir Mydir
 '文件名
 Match = Dir$("*.xlsx")
 Do
 If Not LCase(Match) = LCase(ThisWorkbook.Name) Then
 Workbooks.Open Match, True
 '各工作簿的文件名放到汇总表A列
 ThisWorkbook.ActiveSheet.Range("A" & i) = Match
 
 '各工作簿中SHEET1的B2单元格内容放到汇总表B列
 ThisWorkbook.ActiveSheet.Range("B" & i) = ActiveWorkbook.Sheets("sheet1").Range("A4")

 '各工作簿中SHEET2的B2单元格内容放到汇总表B列'
    ThisWorkbook.ActiveSheet.Range("D" & i) = ActiveWorkbook.Sheets("Sheet2").Range("B2")
    
    ThisWorkbook.ActiveSheet.Range("E" & i) = ActiveWorkbook.Sheets("Sheet2").Range("C2")
 ActiveWorkbook.Close 0
 i = i + 1
 End If
 Match = Dir$
 Loop Until Len(Match) = 0
 Application.ScreenUpdating = True
End Sub

如果需要采集SHEET1其他单元格数据,可以继续添加代码:

ThisWorkbook.ActiveSheet.Range("F" & i) = ActiveWorkbook.Sheets("Sheet1").Range("D3")

如果需要采集SHEET2其他单元格数据,可以继续添加代码:

ThisWorkbook.ActiveSheet.Range("F" & i) = ActiveWorkbook.Sheets("Sheet2").Range("D3")

如果工作簿的工作表、单元格和目标单元格有规律,可以用循环语句解决。

3、效果

在这里插入图片描述

附录

Sub find()

    Application.ScreenUpdating = False
    Dim Mydir As String
    Dim i As Integer
    i = 2
    
    '获取当前VBA所在Excel的路径'
    
    Mydir = ThisWorkbook.Path & "\"
    
    'Left(App.Path, 1)是用来返回路径中第一个字母,即盘符 如:C,D,E,chdrive则是改变当前盘'
    
    ChDrive Left(Mydir, 1)
    
    
    
    ChDir Mydir
    Match = Dir$("*.xls")
    Do
    If Not LCase(Match) = LCase(ThisWorkbook.Name) Then
    Workbooks.Open Match, 0, 1
    '文件名放到汇总表A列'
    ThisWorkbook.ActiveSheet.Range("A" & i) = Match
    
    '各工作簿中SHEET1的B2单元格内容放到汇总表B列'
    ThisWorkbook.ActiveSheet.Range("B" & i) = ActiveWorkbook.Sheets("Sheet1").Range("B2")
    
    ThisWorkbook.ActiveSheet.Range("C" & i) = ActiveWorkbook.Sheets("Sheet1").Range("C2")
     
     '各工作簿中SHEET2的B2单元格内容放到汇总表B列'
    ThisWorkbook.ActiveSheet.Range("D" & i) = ActiveWorkbook.Sheets("Sheet2").Range("B2")
    
    ThisWorkbook.ActiveSheet.Range("E" & i) = ActiveWorkbook.Sheets("Sheet2").Range("C2")
    ActiveWorkbook.Close 0
    i = i + 1
    End If
    Match = Dir$
    Loop Until Len(Match) = 0
    Application.ScreenUpdating = True
End Sub

在这里插入图片描述


http://www.niftyadmin.cn/n/5462528.html

相关文章

Web框架开发-Django-缓存

一、缓存 由于Django是动态网站,所有每次请求均会去数据进行相应的操作,当程序访问量大时,耗时必然会更加明显,最简单解决方式是使用:缓存,缓存将一个某个views的返回值保存至内存或者memcache中&#xff…

JAVAEE之CSS

1.CSS 是什么? 层叠样式表 (Cascading Style Sheets). CSS 能够对网页中元素位置的排版进行像素级精确控制, 实现美化页面的效果. 能够做到页面的样式和结构分离. 1.1 CSS和HTML的区别 CSS,全称为层叠样式表(Cascading Style Sheets),是…

《论文阅读》一种基于反事实推理的会话情绪检测无训练去偏框架 EMNLP 2023

《论文阅读》一种基于反事实推理的会话情绪检测无训练去偏框架 EMNLP 2023 前言简介相关工作模型构架Basic ClassificationBias ExtractionUnbiased Inference实验结果前言 亲身阅读感受分享,细节画图解释,再也不用担心看不懂论文啦~ 无抄袭,无复制,纯手工敲击键盘~ 今天…

[html]基础知识点汇总

前言 经过一阵子学习后,把知识点全部提炼了出来,自我感觉比较全和简洁,希望能够帮到大家。 本机实验环境 火狐浏览器,vscode,windows11,程序运行插件:live server html介绍 html--前端语言…

C++类复习

C类 1. 类内成员函数隐式声明为inline class Str {int x;int y 3; public:inline void fun(){std::cout<<"pf,yes!"<<std::endl;} };这段代码不会报错&#xff0c;但是类内的成员函数隐式声明为inline函数&#xff0c;不需要单独写在前面。因此将成员…

The Morning Star

题目描述 本题有多组数据。 给定 n 个点&#xff0c;第 i 个点的坐标为 xi​&#xff0c;yi​。 现需要将星星和指南针放在任意两个点上&#xff0c;使得星星在指南针的正北、正东、正西、正南、正东南、正东北、正西南或正西北方向&#xff0c;求一共几种放法。&#xff08…

设计模式-单例模式总结

1. 概念 保证一个类只有一个实例并为该实例提供一个全局唯一的访问节点 2. 使用场景 需要频繁进行创建和销毁的对象&#xff0c;如线程池、缓存等。需要在整个系统中保持状态一致的对象&#xff0c;如配置管理器、连接池等。需要确保多个对象共享相同状态的场景&#xff0c;如…

【布式事务】分布式事务和分布式指导理论简介

文章目录 1.分布式事务概念基础概念&#xff1a;事务的4大要求 ACID事务 2.分布式系统设计的指导理论CAP 定理BASE 理论 1.分布式事务概念 基础概念&#xff1a;事务的4大要求 ACID 原子性&#xff08;Atomicity&#xff09;&#xff1a;确保事务作为一个完整的单元执行。如果…