lzh720 发表于 2023-7-26 17:56:56

有偿(已付款答谢)求改进LSP脚本

本帖最后由 lzh720 于 2023-7-26 22:24 编辑

以下是线段统计长度的脚本
===============================
(princ "\n程序:duoduanxianqiuhe 命令:duoduanxian")
(defun C:duoduanxian (/ CURVE TLEN SS N SUMLEN)
(vl-load-com)
(setq SUMLEN 0)
(setq SS (ssget '((0 . "CIRCLE,ELLIPSE,LINE,*POLYLINE,SPLINE,ARC"))))
(setq N 0)
(repeat (sslength SS)
(setq CURVE (vlax-ename->vla-object (ssname SS N)))
(setq TLEN (vlax-curve-getdistatparam CURVE (vlax-curve-getendparam CURVE)))
(setq SUMLEN (+ SUMLEN TLEN))
(setq N (1+ N)))
(setq sumlen(/ sumlen 1000))
(princ (strcat "\n共选择 " (itoa (sslength SS)) " 条线段. 线段总长: " (rtos SUMLEN 2 2)" m"))
(princ) )
==================================
我想让这个脚本里统计的线段长度自动复制到剪贴板里用于复制到EXCEL
需要怎么修改这个脚本?
如果有用的话,我可以微信转账30块答谢(已付款答谢)
=======================
说一下我得软件环境,天正T20V9平台,AUTOCAD2013_64

小鸟 发表于 2023-7-26 21:05:09

本帖最后由 小鸟 于 2023-7-26 21:06 编辑

;;;以下是线段统计长度的脚本
;;;===============================
(princ "\n程序:duoduanxianqiuhe 命令:duoduanxian")
(defun C:duoduanxian (/ CURVE TLEN SS N
          ;SUMLEN
          )
(vl-load-com)
(setq SUMLEN 0)
(setq SS (ssget '((0 . "CIRCLE,ELLIPSE,LINE,*POLYLINE,SPLINE,ARC"))))
(setq N 0)
(repeat (sslength SS)
(setq CURVE (vlax-ename->vla-object (ssname SS N)))
(setq TLEN (vlax-curve-getdistatparam CURVE (vlax-curve-getendparam CURVE)))
(setq SUMLEN (+ SUMLEN TLEN))
(setq N (1+ N)))
(setq sumlen(/ sumlen 1000))
(SET-CLIP-STRING (rtos SUMLEN 2 2))
(princ (strcat "\n共选择 " (itoa (sslength SS)) " 条线段. 线段总长: " (rtos SUMLEN 2 2)" m"))
(princ) )
;;;==================================
;;;我想让这个脚本里统计的线段长度自动复制到剪贴板里用于复制到EXCEL
;;;需要怎么修改这个脚本?
;;;如果有用的话,我可以微信转账30块答谢
;;;
;;;=======================
;;;说一下我得软件环境,天正T20V9平台,AutoCAD2013_64

;;;=================================================================*
;;;功能:向系统剪贴板写入文字                                       *
(defun SET-CLIP-STRING (STR / HTML RESULT)
    (and (= (type STR) 'STR)
   (setq HTML (vlax-create-object "htmlfile"))
   (setq RESULT (vlax-invoke
      (vlax-get (vlax-get HTML 'PARENTWINDOW)
            'CLIPBOARDDATA
      )
      'SETDATA
      "Text"
      STR
          )
   )
   (vlax-release-object HTML)
   (princ "复制到剪贴板")
    )
)
;;;=================================================================*

xj6019 发表于 2023-7-26 19:43:24

lzh720 发表于 2023-7-26 19:40
我原先的脚本用了起码10年,从CAD2007到2023,天正和浩辰都用过,非常稳定可靠,年纪大了,懒得多敲字, ...
你这样试试

(defun C:NM (/ CURVE N SS SUMLEN TLEN zml-clip-setstring)
   (vl-load-com)
      (defun ZML-CLIP-SETSTRING (STR / HTML RESULT);;向系統剪貼板寫入文字
                (setvar "DIMZIN" 8);消除十進制標註中的後續零
                (if(listp STR)
                        (setq str(vl-prin1-to-string STR))
                )
                (and (= (type STR) 'STR)
                        (setq HTML (vlax-create-object "htmlfile"))
                        (setq RESULT (vlax-invoke
                                                                                 (vlax-get      (vlax-get HTML 'PARENTWINDOW)
                                                                                       'CLIPBOARDDATA
                                                                                 )
                                                                                 'SETDATA
                                                                                 "Text"
                                                                                 STR
                                                                         )
                        )
                        (vlax-release-object HTML)
                )
      )
      (ZML-CLIP-SETSTRING "防止出错,占位一下!")   
      (setq SUMLEN 0)
      (setq SS (ssget '((0 . "CIRCLE,ELLIPSE,LINE,*POLYLINE,SPLINE,ARC"))))
      (setq N 0)
      (repeat (sslength SS)
                (setq CURVE (vlax-ename->vla-object (ssname SS N)))
                (setq TLEN (vlax-curve-getdistatparam CURVE (vlax-curve-getendparam CURVE)))
                (setq SUMLEN (+ SUMLEN TLEN))
                (setq N (1+ N)))
      (setq sumlen(/ sumlen 1000))
      (ZML-CLIP-SETSTRING (rtos SUMLEN 2 2))
      (princ (strcat "\n共选择 " (itoa (sslength SS)) " 条线段. 线段总长: " (rtos SUMLEN 2 2)" m"))
      (princ)      
)

xj6019 发表于 2023-7-26 18:03:04

运行完直接去粘贴即可
(defun C:duoduanxian (/ CURVE N SS SUMLEN TLEN zml-clip-setstring)
        (defun ZML-CLIP-SETSTRING (STR / HTML RESULT);;向系統剪貼板寫入文字
                (setvar "DIMZIN" 8);消除十進制標註中的後續零
                (if(listp STR)
                        (setq str(vl-prin1-to-string STR))
                )
                (and (= (type STR) 'STR)
                        (setq HTML (vlax-create-object "htmlfile"))
                        (setq RESULT (vlax-invoke
                                                                               (vlax-get      (vlax-get HTML 'PARENTWINDOW)
                                                                                       'CLIPBOARDDATA
                                                                               )
                                                                               'SETDATA
                                                                               "Text"
                                                                               STR
                                                                       )
                        )
                        (vlax-release-object HTML)
                )
        )
        (vl-load-com)
        (setq SUMLEN 0)
        (setq SS (ssget '((0 . "CIRCLE,ELLIPSE,LINE,*POLYLINE,SPLINE,ARC"))))
        (setq N 0)
        (repeat (sslength SS)
                (setq CURVE (vlax-ename->vla-object (ssname SS N)))
                (setq TLEN (vlax-curve-getdistatparam CURVE (vlax-curve-getendparam CURVE)))
                (setq SUMLEN (+ SUMLEN TLEN))
                (setq N (1+ N)))
        (setq sumlen(/ sumlen 1000))
        (ZML-CLIP-SETSTRING (rtos SUMLEN 2 2))
        (princ (strcat "\n共选择 " (itoa (sslength SS)) " 条线段. 线段总长: " (rtos SUMLEN 2 2)" m"))
        (princ)        
)

ssyfeng 发表于 2023-7-26 18:03:23

只需要复制长度数字就行了吗?还是连这些文字一起复制

lzh720 发表于 2023-7-26 18:04:58

ssyfeng 发表于 2023-7-26 18:03
只需要复制长度数字就行了吗?还是连这些文字一起复制

只需要复制长度,不要带那个m的单位,也不能有空格

ssyfeng 发表于 2023-7-26 18:07:15

(defun C:tt (/ CURVE N SS str SUMLEN TLEN zml-clip-setstring)
        (defun ZML-CLIP-SETSTRING (STR / HTML RESULT)
(and (= (type STR) 'STR)
       (setq HTML (vlax-create-object "htmlfile"))
       (setq RESULT (vlax-invoke
                      (vlax-get      (vlax-get HTML 'PARENTWINDOW)
                              'CLIPBOARDDATA
                      )
                      'SETDATA
                      "Text"
                      STR
                  )
       )
       (vlax-release-object HTML)
)
)
(vl-load-com)
(setq SUMLEN 0)
(setq SS (ssget '((0 . "CIRCLE,ELLIPSE,LINE,*POLYLINE,SPLINE,ARC"))))
(setq N 0)
(repeat (sslength SS)
(setq CURVE (vlax-ename->vla-object (ssname SS N)))
(setq TLEN (vlax-curve-getdistatparam CURVE (vlax-curve-getendparam CURVE)))
(setq SUMLEN (+ SUMLEN TLEN))
(setq N (1+ N)))
(setq sumlen(/ sumlen 1000))
(princ (strcat "\n共选择 " (itoa (sslength SS)) " 条线段. 线段总长: " (setq str (rtos SUMLEN 2 2))" m"))
        (if str (progn (ZML-CLIP-SETSTRING str) (princ (strcat "\n线段总长度:" (setq str (rtos SUMLEN 2 2)) " 已复制到剪切板上。"))))
(princ) )

lzh720 发表于 2023-7-26 18:41:30

ssyfeng 发表于 2023-7-26 18:07
(defun C:tt (/ CURVE N SS str SUMLEN TLEN zml-clip-setstring)
        (defun ZML-CLIP-SETSTRING (STR / HTM ...

命令是TT吗

ssyfeng 发表于 2023-7-26 18:53:06

是的,你自己可以改

lzh720 发表于 2023-7-26 18:53:45

ssyfeng 发表于 2023-7-26 18:07
(defun C:tt (/ CURVE N SS str SUMLEN TLEN zml-clip-setstring)
        (defun ZML-CLIP-SETSTRING (STR / HTM ...


能用但老是报错啊

ssyfeng 发表于 2023-7-26 18:56:33

可以加我qq269126750,帮你看看

lzh720 发表于 2023-7-26 19:04:54

ssyfeng 发表于 2023-7-26 18:56
可以加我qq269126750,帮你看看

修改了你的命令,我改回来TT再试试
页: [1] 2 3
查看完整版本: 有偿(已付款答谢)求改进LSP脚本