ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 求大神写个东西。

[复制链接]

TA的精华主题

TA的得分主题

发表于 2014-6-29 17:33 | 显示全部楼层 |阅读模式
我一个文件夹里,XLS的2000多个,但是我只要获取他O列里面的所有数据,他的格式全部一样,
我要提取D://123文件夹里的XLS表格里面所有的O列,并且保持成一个新的XLS,但是数据过多有可能保存下来超过65535行,自动放到另外一列.
懂的加我Q.、  2028521060 要钱也没事.

TA的精华主题

TA的得分主题

发表于 2014-6-29 17:39 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
问题倒是不大,只是数据量太大的话,效率会成问题。而且会不会有一张表放不下的情况出现?

TA的精华主题

TA的得分主题

发表于 2014-6-29 18:47 | 显示全部楼层
本帖最后由 zhaogang1960 于 2014-6-29 18:56 编辑

假设O列数据没有标题,ADO+数组法请参考:
  1. Sub ADO加数组法()
  2.     Dim Fso As Object, File As Object, cnn As Object, SQL$
  3.     Dim arr, brr(1 To 65536, 1 To 1), f As Boolean, i&, m&, n&
  4.     Application.ScreenUpdating = False
  5.     Application.StatusBar = "                           正在导入数据,请等待……"
  6.     Cells.ClearContents
  7.     Set Fso = CreateObject("Scripting.FileSystemObject")
  8.     For Each File In Fso.GetFolder(ThisWorkbook.Path).Files
  9.         If File.Name Like "*.xls" Then
  10.             If File.Name <> ThisWorkbook.Name Then
  11.                 If Not f Then
  12.                     Set cnn = CreateObject("adodb.connection")
  13.                     cnn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties='Excel 8.0;hdr=no';Data Source=" & File
  14.                     SQL = "select f1 from [Sheet1$o:o] where f1 is not null"
  15.                     f = True
  16.                 Else
  17.                     SQL = "select f1 from [Excel 8.0;hdr=no;Database=" & File & ";].[Sheet1$o:o] where f1 is not null"
  18.                 End If
  19.                 arr = cnn.Execute(SQL).GetRows
  20.                 For i = 0 To UBound(arr, 2)
  21.                     m = m + 1
  22.                     If m > 65536 Then
  23.                         Cells(1, n + 1).Resize(65536) = brr
  24.                         m = 1
  25.                         n = n + 1
  26.                         Erase brr
  27.                     End If
  28.                     brr(m, 1) = arr(0, i)
  29.                 Next
  30.             End If
  31.         End If
  32.     Next
  33.     Cells(1, n + 1).Resize(m) = brr
  34.     Set File = Nothing
  35.     Set Fso = Nothing
  36.     cnn.Close
  37.     Set cnn = Nothing
  38.     Application.StatusBar = False
  39.     Application.ScreenUpdating = True
  40. End Sub
复制代码


评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2014-6-29 18:59 | 显示全部楼层
下面附件中有50个工作簿,请测试效果:
123.rar (1.99 MB, 下载次数: 98)

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-6-30 13:38 | 显示全部楼层
zhaogang1960 发表于 2014-6-29 18:59
下面附件中有50个工作簿,请测试效果:

怎么使用呢?

TA的精华主题

TA的得分主题

发表于 2014-6-30 15:54 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-6-30 18:57 | 显示全部楼层
zhaogang1960 发表于 2014-6-30 15:54
请看演示:

QQ图片20140630181411.jpg
额,我是wps是因为这个的问题吗。

TA的精华主题

TA的得分主题

发表于 2014-6-30 18:59 | 显示全部楼层
overchen 发表于 2014-6-30 18:57
额,我是wps是因为这个的问题吗。

没有用过wps,应该是ADO不认识wps文件格式

TA的精华主题

TA的得分主题

发表于 2014-6-30 19:30 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
zhaogang1960 发表于 2014-6-30 18:59
没有用过wps,应该是ADO不认识wps文件格式

如果有标题怎么办?只要A1单元格一个标题就好了。

复件 123.rar

420.9 KB, 下载次数: 8

TA的精华主题

TA的得分主题

发表于 2014-6-30 19:35 | 显示全部楼层
本帖最后由 zhaogang1960 于 2014-6-30 19:37 编辑
张雄友 发表于 2014-6-30 19:30
如果有标题怎么办?只要A1单元格一个标题就好了。

Sub ADO加数组法()
    Dim Fso As Object, File As Object, cnn As Object, SQL$
    Dim arr, brr(1 To 65535, 1 To 1), f As Boolean, i&, m&, n&
    Application.ScreenUpdating = False
    Application.StatusBar = "                           正在导入数据,请等待……"
    Cells.ClearContents
    Set Fso = CreateObject("Scripting.FileSystemObject")
    For Each File In Fso.GetFolder(ThisWorkbook.Path).Files
        If File.Name Like "*.xls" Then
            If File.Name <> ThisWorkbook.Name Then
                If Not f Then
                    Set cnn = CreateObject("adodb.connection")
                    cnn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties='Excel 8.0;hdr=yes';Data Source=" & File
                    SQL = "select 车间 from [Sheet1$o:o] where 车间 is not null"
                    f = True
                Else
                    SQL = "select 车间 from [Excel 8.0;hdr=yes;Database=" & File & ";].[Sheet1$o:o] where 车间 is not null"
                End If
                arr = cnn.Execute(SQL).GetRows
                For i = 0 To UBound(arr, 2)
                    m = m + 1
                    If m > 65535 Then
                        Cells(1, n + 1) = "车间"
                        Cells(2, n + 1).Resize(65535) = brr
                        m = 1
                        n = n + 1
                        Erase brr
                    End If
                    brr(m, 1) = arr(0, i)
                Next
            End If
        End If
    Next
    Cells(1, n + 1) = "车间"
    Cells(2, n + 1).Resize(m) = brr
    Set File = Nothing
    Set Fso = Nothing
    cnn.Close
    Set cnn = Nothing
    Application.StatusBar = False
    Application.ScreenUpdating = True
End Sub

评分

1

查看全部评分

您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-25 12:04 , Processed in 0.038576 second(s), 15 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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