ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
300集Office 2010微视频教程 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 2222|回复: 10

[求助] 批量删除文件夹内excel指定的列跟行

[复制链接]

TA的精华主题

TA的得分主题

发表于 2019-6-12 08:41 | 显示全部楼层 |阅读模式
想用VBA实现以下功能

1.能够删除原始文档内标黄色的行跟列

2.将文件名称复制到删除后的表格A1单元格内

3.统计光路名称非空白行的数量,并显示在文档名称上

4.此功能最好能够批量操作文件夹内所有的excel文档

修改前:

原始

原始


修改后

修改后

修改后

原始文档.rar (11.02 KB, 下载次数: 1)

修改后.rar (8.35 KB, 下载次数: 2)

TA的精华主题

TA的得分主题

 楼主| 发表于 2019-6-15 10:06 | 显示全部楼层
tz2302200 发表于 2019-6-14 17:19
天霸商务宾馆A座光交(小区光交-)-178.xls
这样?

参考你的第一段代码后已经百度了下,自行修改完成了,谢谢
  1. Sub 重命名()
  2. Dim MyName$
  3. Dim varFileList As Variant

  4. MsgBox "选择要重命名文件所在的文件夹,点击确定!"
  5. With Application.FileDialog(msoFileDialogFolderPicker)
  6.     .AllowMultiSelect = False
  7.     .Show
  8.     If .SelectedItems.Count = 0 Then Exit Sub '未选择文件夹
  9.     renamepath = .SelectedItems(1)
  10.     If Right(renamepath, 1) <> "" Then
  11.         renamepath = renamepath + ""
  12.     End If
  13. End With

  14. '获取文件夹中的所有文件列表
  15. varFileList = fcnGetFileList(renamepath)

  16. If Not IsArray(varFileList) Then
  17.     MsgBox "未找到文件,请重新点击!", vbInformation
  18.     Exit Sub
  19. End If

  20.     MyName = Dir(renamepath & "*.xls")
  21.     For l = 0 To UBound(varFileList)
  22.     Dim fs
  23.     Set fs = CreateObject("Scripting.FileSystemObject")
  24.         With Workbooks.Open(renamepath & MyName)
  25.             .Sheets(1).Select
  26.             CC = Application.CountA(ActiveSheet.Range("C:C")) - 1
  27.             .Close True
  28.         End With
  29.         oName = renamepath & CStr(varFileList(l))
  30.         nName = Left(MyName, Len(MyName) - 4) & "-" & CC & ".xls"
  31.         Name oName As nName
  32.         MyName = Dir
  33.     Next l
  34. Application.ScreenUpdating = True
  35. MsgBox "全部重命名成功!", vbInformation

  36. End Sub

  37. Private Function fcnGetFileList(ByVal strPath As String, Optional strFilter As String) As Variant
  38. ' 将文件列表放到数组
  39. Dim f As String
  40. Dim i As Integer
  41. Dim FileList() As String

  42. If strFilter = "" Then strFilter = "*.*"
  43.     Select Case Right(strPath, 1)
  44.     Case "", "/"
  45.     strPath = Left(strPath, Len(strPath) - 1)
  46. End Select

  47. ReDim Preserve FileList(0)
  48. f = Dir(strPath & "" & strFilter)
  49. Do While Len(f) > 0
  50.     ReDim Preserve FileList(i) As String
  51.     FileList(i) = f
  52.     i = i + 1
  53.     f = Dir()
  54. Loop
  55. If FileList(0) <> Empty Then
  56.     fcnGetFileList = FileList
  57. Else
  58.     fcnGetFileList = False
  59. End If

  60. End Function
复制代码


TA的精华主题

TA的得分主题

 楼主| 发表于 2019-6-12 09:34 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
有米有高手帮忙解决下啊

TA的精华主题

TA的得分主题

发表于 2019-6-12 11:18 | 显示全部楼层
  • 打开vba.xlsm
  • 点击按钮1
  • 文件夹下的所有文件均修改成你所希望的格式

实例.zip

39.25 KB, 下载次数: 10

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2019-6-12 12:03 | 显示全部楼层
tz2302200 发表于 2019-6-12 11:18
  • 打开vba.xlsm
  • 点击按钮1
  • 文件夹下的所有文件均修改成你所希望的格式

  • 你好,为啥我点了之后没反应啊?

    TA的精华主题

    TA的得分主题

     楼主| 发表于 2019-6-12 12:06 | 显示全部楼层
    [广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
    tz2302200 发表于 2019-6-12 11:18
  • 打开vba.xlsm
  • 点击按钮1
  • 文件夹下的所有文件均修改成你所希望的格式

  • 一点之后就excel闪退了。。

    TA的精华主题

    TA的得分主题

     楼主| 发表于 2019-6-12 12:12 | 显示全部楼层
    tz2302200 发表于 2019-6-12 11:18
  • 打开vba.xlsm
  • 点击按钮1
  • 文件夹下的所有文件均修改成你所希望的格式

  • 可否点击按钮可以自己选择文件夹的目录?

    TA的精华主题

    TA的得分主题

    发表于 2019-6-14 10:17 | 显示全部楼层
    悪い男 发表于 2019-6-12 12:12
    可否点击按钮可以自己选择文件夹的目录?

    不要放在与被执行的文件的同文件夹

    vba.7z

    18.2 KB, 下载次数: 2

    TA的精华主题

    TA的得分主题

    发表于 2019-6-14 10:18 | 显示全部楼层

    TA的精华主题

    TA的得分主题

     楼主| 发表于 2019-6-14 13:38 | 显示全部楼层
    [广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
    tz2302200 发表于 2019-6-14 10:18
    闪退我也不懂怎么处理

    前几个功能都实现了。

    3.统计光路名称非空白行的数量,并显示在文档名称上

    再加一个重命名的有没?

    名称格式<原文档名称>-<数量>

    例子:天霸-178

    TA的精华主题

    TA的得分主题

    发表于 2019-6-14 17:19 | 显示全部楼层
    [广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
    悪い男 发表于 2019-6-14 13:38
    前几个功能都实现了。

    3.统计光路名称非空白行的数量,并显示在文档名称上

    天霸商务宾馆A座光交(小区光交-)-178.xls
    这样?
    您需要登录后才可以回帖 登录 | 免费注册

    本版积分规则

    手机版|关于我们|联系我们|ExcelHome

    GMT+8, 2024-5-6 19:44 , Processed in 0.054436 second(s), 15 queries , Gzip On, MemCache On.

    Powered by Discuz! X3.4

    © 1999-2023 Wooffice Inc.

    沪公网安备 31011702000001号 沪ICP备11019229号-2

    本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

    快速回复 返回顶部 返回列表