ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[原创] 通用Word表格导入工具_Doc2Xls

  [复制链接]

TA的精华主题

TA的得分主题

 楼主| 发表于 2013-7-22 21:20 | 显示全部楼层
本帖最后由 Moneky 于 2013-7-30 09:34 编辑

20130722 更新:
1、 自动修复Word引用,自动适应不同的Word版本。实现本功能需要在信任中心中设置 信任对VBE对象模型的引用  ,目前代码可以自己读取更改该设置(借鉴某个病毒的代码),采用Shell来读写注册表,因此可能会被一些过于过敏的杀软误杀(我的Mcafee没有误报)。程序只会根据需要更改设置,应用添加后会自动还原设置。

2、读取模板时的过多警告信息在现实3次后可以选择忽略它。

3、我电脑是是2013版,没有进行过多测试,如有问题欢迎反馈。


20130723 更新
     修复22日更新中的优化提示功能失效问题

此楼附件已删除,请下最新版

TA的精华主题

TA的得分主题

发表于 2013-7-22 22:04 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
大侠,我做了Word文档,代码有问题,请指教:
1、能查看Word文档里有几个表格。
2、每个表格有几行,几列?非要鼠标选择那个表格才看出来,怎么修改?
3、指定表格里第n行n列的内容是什么?怎么修改代码。
谢谢!

查询表格1.zip

8.88 KB, 下载次数: 177

TA的精华主题

TA的得分主题

 楼主| 发表于 2013-7-22 23:02 | 显示全部楼层
banjinjiu 发表于 2013-7-22 22:04
大侠,我做了Word文档,代码有问题,请指教:
1、能查看Word文档里有几个表格。
2、每个表格有几行,几列 ...
  1. Sub 表格()
  2.     Dim shtCount As Long
  3.     Dim vIndex As Long, lngRowC As Long, lngColumnC As Long, strTmp As String, strTmp2 As String
  4.     Dim vTab As Table
  5.     With ThisDocument
  6.         shtCount = .Tables.Count
  7.         For Each vTab In .Tables
  8.             vIndex = vIndex + 1
  9.             lngRowC = vTab.Rows.Count
  10.             lngColumnC = vTab.Columns.Count
  11.             strTmp = vTab.Cell(1, 1).Range.Text '这里设置第几行几列
  12.             strTmp2 = "该文档共有a张表,第b张表共c行d列,第1行第1列内容为" & strTmp
  13.             strTmp2 = Replace$(strTmp2, "a", CStr(shtCount))
  14.             strTmp2 = Replace$(strTmp2, "b", CStr(vIndex))
  15.             strTmp2 = Replace$(strTmp2, "c", CStr(lngRowC))
  16.             strTmp2 = Replace$(strTmp2, "d", CStr(lngColumnC))
  17.             MsgBox strTmp2, vbInformation + vbOKOnly, "Eersoft-提示"
  18.         Next
  19.     End With
  20. End Sub
复制代码

TA的精华主题

TA的得分主题

发表于 2013-7-22 23:18 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2013-7-29 19:10 | 显示全部楼层
本帖最后由 Moneky 于 2013-8-11 11:09 编辑

20130729 更新
概述:添加了对表格在文本框中的文档的支持——所有表格均在文本框中。感谢提供文档的 随风 朋友。。。。
  其它说明:
  • 代码会在导入这些文档的过程中更改其内容——将文本框外的内容清空,将文本框中的表格提取出来,再删除所有文本框。虽然最终代码不会保存这些更改,但以防万一,最好先备份需要导入的文档。
  • 很遗憾的证明,上次更新添加的自动引用Word功能还存在缺陷,某些情况下无法自动引用,还需要手动去除错误的Word引用,添加正确引用。
  • 下载好用的朋友们,求顶啊!

20130730 更新
概述:添加了忽略所有错误强制导入的选项,用以排除特殊数据的干扰,只是导入后需要手工进行核对一下。
20130811 更新
现在应该可以正常的自动添加对Word的引用了。

最新界面预览:
2013-07-30_092011.png

esDoc2Xls_2007_2010_2013.rar

286.51 KB, 下载次数: 1339

20130811

esDoc2Xls_2003.rar

273.05 KB, 下载次数: 692

20130811

TA的精华主题

TA的得分主题

 楼主| 发表于 2013-7-30 09:36 | 显示全部楼层
20130730 更新  添加了忽略所有错误的选项,可以避免一些特殊数据造成的错误

TA的精华主题

TA的得分主题

发表于 2013-8-7 18:58 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2013-8-7 19:21 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
碧落苍穹 发表于 2013-8-7 18:58
东西是好东西,可惜总出错,郁闷

你说的错误解决如下:
1、打开VBE
2、依次点击菜单【工具】→【引用】
3、在弹出的对话框中,去掉前面有“丢失*****"字样条目的勾
4、在列表中找到类似  Microsoft Word ××.× Object Library 的条目,并选中
5、点击【确定】按钮。OK,enjoy it!

15.0 的数字可能不一样,选中就是了。

15.0 的数字可能不一样,选中就是了。

TA的精华主题

TA的得分主题

 楼主| 发表于 2013-8-11 11:10 | 显示全部楼层
20130811 再次更新,现在自动添加引用应该更靠谱一些了。附件在35楼

TA的精华主题

TA的得分主题

发表于 2013-8-11 11:13 | 显示全部楼层
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-12-27 10:17 , Processed in 0.033956 second(s), 8 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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