明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1753|回复: 3

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

[复制链接]
发表于 2014-2-8 07:52:25 | 显示全部楼层 |阅读模式
请各位帮忙解决,下面的VBA代码如何修改,才可以让选择的直线或多线长度统计到EXCEL的一个单元格内,各长度进行累加,显示长度计算式,先谢谢
  1. Public Sub getlength() '统计长度
  2. Set acadApp = GetObject(, "AutoCAD.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
发表于 2014-2-8 21:20:34 | 显示全部楼层

  1.     With Xlapp
  2.         k = .ActiveCell.row '电子表格中当前单元格的 行号
  3.         j = .ActiveCell.Column'当前单元格的 列号
  4.         For Each entry In sjx
  5.             hjx = entry.Length'获得长度
  6.             .cells(k, j) = Format(hjx / 1000, "##0.00")'在单元格(k行,j列)中写入长度(除以1000),显示两位小数
  7.             k = k + 1'累加行号
  8.             .cells(k, j).Activate'将单元格(k行,j列)置为当前
  9.         Next entry
  10.     End With
复制代码
从上面可以看出,取得一个图形元素的长度,单元格就会递增(累加)一行。
如果只想写入一个单元格内,则按下面的代码

  1. dim tmpStr as string

  2.     With Xlapp
  3.         k = .ActiveCell.row '电子表格中当前单元格的 行号
  4.         j = .ActiveCell.Column'当前单元格的 列号
  5.         For Each entry In sjx
  6.             hjx = entry.Length'获得长度
  7. hj=hj+hjx'累加线段长度
  8. tmpStr =tmpStr  &"  "& str(hjx )'将长度转换为字符,保存长度

  9.         Next entry
  10. .cells(k, j) =tmpStr '所有线段的长度空格隔开放在一个单元格中
  11. .cells(k+1, j) =hj'在下一行中写入所有线段的长度和
  12.     End With
复制代码
 楼主| 发表于 2014-2-10 20:20:51 | 显示全部楼层
谢谢vbcad的帮助,调试成功了,十分感谢!
发表于 2014-2-11 12:17:22 | 显示全部楼层
jsxygshh 发表于 2014-2-10 20:20
谢谢vbcad的帮助,调试成功了,十分感谢!

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

本版积分规则

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

GMT+8, 2024-11-25 12:29 , Processed in 0.166514 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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