乐筑天下

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

用数组的形式统计直线长度到EXCEL一个单元格中

[复制链接]

6

主题

34

帖子

2

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
58
发表于 2014-2-8 07:52:00 | 显示全部楼层 |阅读模式
请各位帮忙解决,下面的VBA代码如何修改,才可以让选择的直线或多线长度统计到EXCEL的一个单元格内,各长度进行累加,显示长度计算式,先谢谢
  1. Public Sub getlength() '统计长度
  2. Set acadApp = GetObject(, ".Application")
  3. Set Xlapp = GetObject(, "Excel.Application")
  4.     Dim entry As AcadEntity, hjx As Variant, FType(0) As Integer, FData(0) As Variant, sjx As AcadSelectionSet, i As Long
  5.     FType(0) = 0
  6.     FData(0) = "Length"
  7.     On Error Resume Next
  8.     ThisDrawing.SelectionSets.Item("sf").Delete
  9.     Set sjx = acadApp.ActiveDocument.SelectionSets.Add("sf")
  10.     sjx.SelectOnScreen
  11.     h = sjx.Count
  12.     sjx.Select acSelectionSetAll, , , FType, FData
  13.     With Xlapp
  14.         k = .ActiveCell.row
  15.         j = .ActiveCell.Column
  16.         For Each entry In sjx
  17.             hjx = entry.Length
  18.             .cells(k, j) = Format(hjx / 1000, "##0.00")
  19.             k = k + 1
  20.             .cells(k, j).Activate
  21.         Next entry
  22.     End With
  23.     sjx.Delete
  24. End Sub
回复

使用道具 举报

13

主题

59

帖子

2

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
111
发表于 2014-2-8 21:20:00 | 显示全部楼层
复制代码从上面可以看出,取得一个图形元素的长度,单元格就会递增(累加)一行。
如果只想写入一个单元格内,则按下面的代码复制代码
回复

使用道具 举报

6

主题

34

帖子

2

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
58
发表于 2014-2-10 20:20:00 | 显示全部楼层
谢谢vbcad的帮助,调试成功了,十分感谢!
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-4-20 18:05 , Processed in 2.898526 second(s), 58 queries .

© 2020-2025 乐筑天下

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