明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 2057|回复: 5

分享一个excel表格转CAD的

[复制链接]
发表于 2018-8-23 16:52:50 | 显示全部楼层 |阅读模式
程序是几个星期前写的,因为懒,就不改了,需要的人可以根据注释修改,很容易移植的。用了很久,暂时没发现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




评分

参与人数 2明经币 +1 金钱 +30 收起 理由
hefeilac + 1 + 20 感谢你的无私
mikewolf2k + 10 赞一个!

查看全部评分

发表于 2018-10-3 10:53:10 | 显示全部楼层
LZ代码全吗怎么使用呀
发表于 2018-12-21 09:32:16 | 显示全部楼层
代码不全,能不能给个全面的代码?
发表于 2019-4-15 15:39:37 | 显示全部楼层

代码不全,能不能给个全面的代码?
发表于 2019-6-3 06:26:35 | 显示全部楼层

可否介绍一下使用方法
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-25 03:53 , Processed in 0.657337 second(s), 28 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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