乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 132|回复: 5

分享一个excel表格转CAD的

[复制链接]

11

主题

38

帖子

1

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
82
发表于 2018-8-23 16:52:00 | 显示全部楼层 |阅读模式
程序是几个星期前写的,因为懒,就不改了,需要的人可以根据注释修改,很容易移植的。用了很久,暂时没发现BUG。
  1. Sub 画表格填内容(ByVal pt, ByVal i, ByVal j, ByVal A, ByVal B)
  2. 'B存放列宽,行高,字体大小
  3. 'B第一行是列宽,第二行是行高,第三行是字高
  4. 'p是左下角插入点,pt是左下角插入点
  5. 'i行,j列
  6. '列从左至右,行从下至上
  7. 'A是EXCEL 里面要放的表格数据
  8. Dim p1(0 To 2) As Double, p2(0 To 2) As Double, p3(0 To 2) As Double
  9. Dim k&, x As Double, y As Double, z As Object
  10. Dim zg As Double, p(0 To 2) As Double, w As Double, h As Double
  11. zg = B(3, 1) * 35 / 50
  12. h = B(3, 1)
  13. '求左下角插入点p
  14. p(1) = pt(1)
  15. p(0) = pt(0)
  16. For k = 1 To j
  17.     p(0) = p(0) - B(1, k)
  18. Next k
  19. '画竖线
  20. For k = 1 To i
  21.      p2(1) = p2(1) + B(2, k)
  22. Next k
  23. p1(0) = p(0): p1(1) = p(1)
  24. p2(0) = p1(0): p2(1) = p1(1) + p2(1)
  25. Set z = acadDoc.modelspace.AddLine(p1, p2)
  26. For k = 1 To j
  27.     p1(0) = p1(0) + B(1, k)
  28.     p2(0) = p1(0)
  29.     Set z = acadDoc.modelspace.AddLine(p1, p2)
  30. Next k
  31. '画横线
  32. p1(0) = p(0)
  33. p2(1) = p(1)
  34. Set z = acadDoc.modelspace.AddLine(p1, p2)
  35. For k = 1 To i
  36.     p1(1) = p1(1) + B(2, k)
  37.     p2(1) = p1(1)
  38.     Set z = acadDoc.modelspace.AddLine(p1, p2)
  39. Next k
  40. '放文字内容
  41. '文字宽度 英文是35/50*zg,中文35/50*zg*2
  42. p3(0) = p(0): p3(1) = p(1)
  43. For y = 1 To j
  44.     p3(0) = p3(0) + B(1, y)
  45.     p3(1) = p(1)
  46.     For x = 1 To i
  47.         p3(1) = p3(1) + B(2, x)
  48.         If A(x, y)  "" Then
  49.             w = 0
  50.             For k = 1 To Len(A(x, y))
  51.                 If Asc(Mid(A(x, y), k, 1)) > 0 Then
  52.                     w = w + zg
  53.                 Else
  54.                     w = w + zg * 2
  55.                 End If
  56.             Next k
  57.             p1(0) = p3(0) - w - (B(1, y) - w) / 2
  58.             p1(1) = p3(1) - h - (B(2, x) - h) / 2
  59.             Set z = acadDoc.modelspace.addtext(A(x, y), p1, h)
  60.         End If
  61.     Next x
  62. Next y
  63. End Sub

回复

使用道具 举报

14

主题

52

帖子

8

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
109
发表于 2018-10-3 10:53:00 | 显示全部楼层
LZ代码全吗怎么使用呀
回复

使用道具 举报

1

主题

3

帖子

1

银币

初来乍到

Rank: 1

铜币
7
发表于 2018-12-21 09:32:00 | 显示全部楼层
代码不全,能不能给个全面的代码?
回复

使用道具 举报

0

主题

1

帖子

1

银币

初来乍到

Rank: 1

铜币
1
发表于 2019-4-15 15:39:00 | 显示全部楼层

代码不全,能不能给个全面的代码?
回复

使用道具 举报

1

主题

6

帖子

3

银币

初来乍到

Rank: 1

铜币
10
发表于 2019-4-30 00:31:00 | 显示全部楼层
非常感谢
回复

使用道具 举报

43

主题

153

帖子

9

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
325
发表于 2019-6-3 06:26:00 | 显示全部楼层

可否介绍一下使用方法
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2024-11-22 00:07 , Processed in 0.147666 second(s), 64 queries .

© 2020-2024 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表