vba:文件夹和文件夹的处理,dir

news2024/12/26 23:36:01

Option Explicit

'1 判断文件夹是否存在
   'dir函数的第二个参数是vbdirectory时可以返回路径下的指定文件和文件夹,如果结果为"",则表示不存在。
  Sub w1()
    If Dir(ThisWorkbook.path & "\2011年报表2", vbDirectory) = "" Then
       MsgBox "不存在"
    Else
       MsgBox "存在"
    End If
  End Sub

解释:dir

在VBA中,Dir函数被用于返回匹配指定文件名模式的第一个文件或目录的名称。下面是Dir函数的语法和使用方法:

Dir([path], [attributes])

参数

  • path(可选):要检索的路径字符串。如果省略,将从当前目录开始搜索。
  • attributes(可选):指定要搜索的文件类型。默认包括普通文件和文件夹。可以通过组合以下常量来定义:
常量描述
vbNormal文件或目录
vbReadOnly只读文件
vbHidden隐藏文件或目录
vbSystem系统文件或目录
vbArchive档案文件
vbDirectory返回目录,默认也会返回文件
vbAlias返回文件或目录的别名(仅 macOS)
vbVolume返回卷标(移动设备路径。仅 macOS)

返回值

  • String:文件/目录的名称。如果没有找到匹配的文件,则返回空字符串""。

示例

以下示例演示如何使用Dir函数获取符合条件的文件名:

Sub DirExample()

    Dim MyFile As String
    
    ' 获取C:\Users\YourName\Desktop文件夹下的所有.xls文件名
    MyFile = Dir("C:\Users\YourName\Desktop\*.xls")
    
    ' 循环显示所有满足条件的文件名
    Do While MyFile <> ""
        Debug.Print MyFile
        MyFile = Dir()
    Loop
    



End Sub
'2 新建文件夹
   'Mikdir语句可以创建一个文件夹
    Sub w2()
      MkDir ThisWorkbook.path & "\Test"
    End Sub


   案例:

Sub CreateNewDirectory()

    Dim PathStr as String
    
    ' 创建名为"NewFolder"的新目录在"C:\Users\YourName\Desktop"
    PathStr = "C:\Users\YourName\Desktop\NewFolder"
    MkDir PathStr
    
End Sub
 


'3 删除文件夹
   
   'RmDir语句可以删除一个文件夹,如果想要使用 RmDir 来删除一个含有文件的目录或文件夹,则会发生错误。
   '在试图删除目录或文件夹之前,先使用 Kill 语句来删除所有文件。
   
    Sub w3()
      RmDir ThisWorkbook.path & "\test"
    End Sub
'4 文件夹重命名
    Sub w4()
      Name ThisWorkbook.path & "\test" As ThisWorkbook.path & "\test2"
    End Sub
     
'5 文件夹移动
     '同样使用name方法,可以达到移动的效果,而且连文件夹的文件一起移动
    
    Sub w5()
      Name ThisWorkbook.path & "\test2" As ThisWorkbook.path & "\2011年报表\test100"
    End Sub
    
'6 文件夹复制
        Sub CopyFile_fso()
        Dim fso As Object
        Set fso = CreateObject("Scripting.FileSystemObject")
        fso.CopyFolder ThisWorkbook.path & "\测试新建文件夹", ThisWorkbook.path & "\2011年报表\"
        Set fso = Nothing
        End Sub

解释:Scripting.FileSystemObject

CreateObject("Scripting.FileSystemObject") 在 VBA 中用于创建一个文件系统对象,使代码能够访问和操作计算机上的文件或文件夹。

以下是使用 FileSystemObject 的一些常见操作:

  1. 获取文件大小

要获取文件的大小,可以使用 FilesystemObjectGetFile 方法和 Size 属性,例如:

Dim fs As Object
Set fs = CreateObject("Scripting.FileSystemObject")
Dim file As Object
Set file = fs.GetFile("C:\Users\example.txt")
MsgBox file.Size ' 返回字节数

  1. 创建文件夹

要在指定路径中创建新文件夹,可以使用 Folder 对象的 CreateFolder 方法,例如:

Dim fs As Object
Set fs = CreateObject("Scripting.FileSystemObject")
fs.CreateFolder "C:\NewFolder"

  1. 复制、移动和删除文件

要复制文件,使用 FilesystemObjectCopyFile 方法:

Dim fs As Object
Set fs = CreateObject("Scripting.FileSystemObject")
fs.CreateFolder "C:\NewFolder"
同样的,要移动文件,使用 MoveFile 方法:

Dim fs As Object
Set fs = CreateObject("Scripting.FileSystemObject")
fs.MoveFile "C:\OldFolder\example.txt", "C:\NewFolder\example.txt"


要删除文件,使用 DeleteFile 方法:

Dim fs As Object
Set fs = CreateObject("Scripting.FileSystemObject")
fs.DeleteFile "C:\OldFolder\example.txt"
 

  1. 复制、移动和删除文件夹

要复制文件夹,使用 FilesystemObjectCopyFolder 方法:

Dim fs As Object
Set fs = CreateObject("Scripting.FileSystemObject")
fs.CopyFolder "C:\OldFolder", "C:\NewFolder"
 

同样的,要移动文件夹,使用 MoveFolder 方法:

Dim fs As Object
Set fs = CreateObject("Scripting.FileSystemObject")
fs.MoveFolder "C:\OldFolder", "C:\


'7 打开文件夹
   '使用shell函数桌面管理程序打开文件夹
    Sub w7()
      Shell "explorer.exe " & ThisWorkbook.path & "\2011年报表", 1
    End Sub

 解释:shell函数

在 VBA 中,Shell 函数的语法如下:

 

复制代码

Shell (pathname As String, [windowstyle As VbAppWinStyle = vbMinimizedFocus])

其中 pathname 参数是要运行的可执行文件的完整路径和名称,例如 C:\Program Files\Microsoft Office\Office14\WINWORD.EXE

windowstyle 参数是可选的,它指定了应用程序窗口的外观。以下是可用的 VbAppWinStyle 常量:

  • vbHide:隐藏窗口并激活另一个窗口。
  • vbNormalFocus:以正常大小和位置显示窗口,并将焦点设置为窗口。
  • vbMinimizedFocus:以最小化的形式显示窗口,并将焦点设置为窗口。
  • vbMaximizedFocus:以最大化的形式显示窗口,并将焦点设置为窗口。
  • vbNormalNoFocus:以正常大小和位置显示窗口,但不将焦点设置为窗口。
  • vbMinimizedNoFocus:以最小化的形式显示窗口,但不将焦点设置为窗口。

例如,以下代码将打开 Microsoft Word 并最小化它的窗口

Sub OpenWord()
    Shell "C:\Program Files\Microsoft Office\Office14\WINWORD.EXE", vbMinimizedFocus
End Sub
请注意,使用 Shell 函数启动另一个应用程序后,您可能需要等待其加载并准备好处理用户输入。您可以使用 VBA 的 Wait 函数来暂停代码执行,例如:

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

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

相关文章

( “树” 之 BST) 230. 二叉搜索树中第K小的元素 ——【Leetcode每日一题】

二叉查找树&#xff08;BST&#xff09;&#xff1a;根节点大于等于左子树所有节点&#xff0c;小于等于右子树所有节点。 二叉查找树中序遍历有序。 230. 二叉搜索树中第K小的元素 给定一个二叉搜索树的根节点 root &#xff0c;和一个整数 k &#xff0c;请你设计一个算法查…

Oracle中Interval几种常用的写法

目录 每分钟执行&#x1f4a8; 每天定时执行&#x1f4a8; 每周定时执行&#x1f4a8; 每月定时执行&#x1f4a8; 每季度定时执行&#x1f4a8; 每半年定时执行&#x1f4a8; 每年定时执行&#x1f4a8; 其他更多示例&#x1f937;‍♀️&#x1f937;‍♀️ 每分钟执…

【线性dp 例题 大综合】dp——数字三角形模型【线性dp】

数字三角形模型 一、数字三角形模型1. 摘花生(最大值)2. 最低通行费(需要把边界置成0x3f)我的错题点 3. ★★★ 取方格数路径长度为k,第一条路线到x1i,第二条路线到x2j的所有方案 4. ★★★★★ 传纸条就是 取方格数 的 题意延申一下 0x51 线性dp经典例题&#xff1a;LIS LCS 数…

Databend v1.1 版本发布!

各位社区小伙伴们&#xff0c;Databend 于 2023 年 4 月 14 日迎来了 v1.1.0 版本的正式发布&#xff01; 这次新版本是 Databend 发布1.0 版本之后的第一个大版本&#xff01;相较于 v1.0.0 版本&#xff0c;开发者们一共新增了 1,616 次commit&#xff0c; 共计 505 个优化和…

程序员跳槽,要求涨薪50%过分吗?

如果问在TI行业涨工资最快的方式是什么&#xff1f; 回答最多的一定是&#xff1a;跳槽&#xff01; 前段时间&#xff0c;知乎上这样一条帖子引发了不少IT圈子的朋友的讨论 &#xff0c;有网友提问 “程序员跳槽要求涨薪50%过分吗&#xff1f;” 截图来源于知乎&#xff0c;…

uni-app生成海报并分享

lime-painter是一款canvas海报组件&#xff0c;可以更轻松的生成海报 海报画板 - DCloud 插件市场 一款canvas海报组件&#xff0c;更优雅的海报生成方案https://ext.dcloud.net.cn/plugin?id2389插件提供 JSON 及 Template 的方式绘制海报 1、Template方式 提供l-painter-…

【Transformer系列(4)】Transformer模型结构超详细解读

前言 前一篇我们一起读了Transformer的论文《Attention Is All You Need》&#xff0c;不知道大家是否真的理解这个传说中的神&#xff08;反正俺是没有~&#xff09; 这两天我又看了一些视频讲解&#xff0c;感谢各位大佬的解读&#xff0c;让我通透了不少。 这篇文章就和…

前沿的Web前端技术趋势与应用实践

近年来&#xff0c;Web前端技术发展迅猛&#xff0c;各种新技术层出不穷&#xff0c;为了跟上潮流&#xff0c;我们需要不断学习新知识&#xff0c;应用新技术&#xff0c;不断提高自己的技术水平&#xff0c;为自己的职业生涯打下坚实的基础。本篇博客将为大家详细介绍前沿的W…

【Mysql】主从复制

【Mysql】主从复制 文章目录 【Mysql】主从复制1. 概述2. 原理3. 搭建3.1 准备工作3.2 主库配置3.3 从库配置 1. 概述 主从复制是指主数据库的 DDL 和 DML 操作通过二进制日志传到从库服务器中&#xff0c;然后再从库上对这些日志重新执行(也叫重做)&#xff0c;从而使得从库和…

小红书行业趋势分析,女性种草关键词有哪些?

在“她力量”崛起的当今&#xff0c;女性用户正不断引领新潮流&#xff0c;驱动产品、内容升级。女性个人观念、生活方式、消费偏好演变&#xff0c;需求重点势必不断更新。 今儿就女性用户的聚集地小红书平台&#xff0c;以及女性最关注的美妆、母婴两大行业&#xff0c;通过数…

完整支持Oracle PL/SQL,星环科技KunDB高兼容性实现低成本国产化替代

从中兴、华为等一系列高新科技企业被美国制裁&#xff0c;到俄乌冲突事件爆发后&#xff0c;西方各国相继宣布制裁俄罗斯&#xff0c;以Oracle、IBM、微软、SAP为代表的科技巨头暂停在俄服务&#xff0c;这一系列动作给我们敲响了加速国产化替代的警钟。数据库作为提供数据存储…

2024年浙大MBA提前批面试即将开始申请,如何操作?

在去年的这个时间点&#xff0c;浙大MBA提前批面试的申请系统已经打开并可以正常开始接受申请报名&#xff0c;而今年的申请时间会在什么时间点&#xff1f;那么又如何准备浙大MBA的提面申请呢&#xff1f;本期专注浙大的杭州达立易考教育为大家做一下梳理&#xff0c;帮助大家…

【机器学习】P21 正则化 Regularization(L1正则化 Lasso、L2正则化 Ridge、弹性网络正则化、Dropout正则化、早停法)

既然模型有概率发生过拟合现象&#xff0c;那么如何才能减少过拟合&#xff0c;或者防止过拟合的产生&#xff1f;方法之一就是正则化方法&#xff0c;Regularization&#xff1b; 我对正则化&#xff0c;有这样的理解&#xff1a;“我们既希望能够通过权重的调整从而建立更好…

数据结构考研版——括号的匹配问题栈的计算问题

一、括号的匹配问题 这玩意太简单了没什么讲头&#xff0c;就是括号一个一个进栈&#xff0c;匹配就出&#xff0c;以此类推 二、括号匹配问题代码 int isMatched(char left, char right) {if (left (&& right ))return 1;else if (left [ && right ])ret…

还在发愁项目去哪找?软件测试企业级Web自动化测试实战项目

今天给大家分享一个简单易操作的实战项目&#xff08;已开源&#xff09; 项目名称 ET开源商场系统 项目描述 ETshop是一个电子商务B2C电商平台系统&#xff0c;功能强大&#xff0c;安全便捷。适合企业及个人快速构建个性化网上商城。 包含PCIOS客户端Adroid客户端微商城…

Java语法理论和面经杂疑篇《十. 反射机制》

目录 1. 反射(Reflection)的概念 1.1 反射的出现背景 1.2 反射概述 1.3 Java反射机制研究及应用 1.4 反射相关的主要API 1.5 反射的优缺点 2. 理解Class类并获取Class实例 2.1 理解Class 2.1.1 理论上 2.1.2 内存结构上 2.2 获取Class类的实例(四种方法) 2.3 哪些类…

设计模式:创建者模式 - 原型模式

文章目录 1.概述2.结构3.实现4.案例5.使用场景6.扩展&#xff08;深克隆&#xff09; 1.概述 用一个已经创建的实例作为原型&#xff0c;通过复制该原型对象来创建一个和原型对象相同的新对象。 2.结构 原型模式包含如下角色&#xff1a; 抽象原型类&#xff1a;规定了具体…

nodejs+vue宠物商城健康医院挂号服务管理系统python+java+php

在前台&#xff0c;首先提供一个界面清晰、导航明确的首页&#xff0c;无论是会员还是游客都可以访问。游客通过首页查看该网站所要具备的功能&#xff0c;以及对应的周边商城信息&#xff0c;特别在周边商城模块&#xff0c;需要明确的进行介绍&#xff0c;突出周边商城特色和…

如何主动增加自己的开源项目star数的方法汇总

本篇文章主要讲解&#xff0c;通过自媒体、短视频、网络平台等渠道形式增加自己的开源项目的曝光度以增加star数的方法。 作者&#xff1a;任聪聪 日期&#xff1a;2023年4月20日 开源项目的star数在某些找工作的情况下是有一定的加分的&#xff0c;故此价值是一定的。但是自己…

arm64异常向量表

arm64异常向量表 1 arm64异常向量表2 linux arm64异常向量表3 kernel_ventry宏4 异常向量表的保存4. VBAR_ELx寄存器4.2 __primary_switched4.3 __primary_switched 1 arm64异常向量表 When an exception occurs, the processor must execute handler code which corresponds t…