天气与日历 切换到窄版

 找回密码
 立即注册
中国膜结构网
十大进口膜材评选 十大国产膜材评选 十大膜结构设计评选 十大膜结构公司评选
查看: 65|回复: 0

Lisp向excel注入vba代码

[复制链接]

该用户从未签到

主题

0

回帖

2912

积分

管理员

积分
2912
发表于 2024-6-22 09:46:18 | 显示全部楼层 |阅读模式
Lisp向excel注入vba代码



(defun $excel-add-vba$
       (xlapp sh-n VBA-STR run-str lst / item vbproject xlsheet)
                    ;向excel里面写vba代码,注入vba代码
;;;  ($excel-add-vba$
;;;  xlapp
;;;  "Sub Lisp_vba()\nMsgBox \"Hello world!\", vbOKOnly, \"Lisp调用Excel\"\nEnd Sub"
;;;  "(vlax-invoke-method XLAPP (QUOTE RUN) \"Sheet1.Lisp_vba\")"
;;;  "Sheet1"
;;;  nil
;;; )
  (or xlapp (setq xlapp ($xlapp-New$ nil nil nil)))
  (setq    xlsheet
     (vl-catch-all-apply
       'vlax-get-property
       (list (vl-catch-all-apply
           'vlax-get-property
           (list (vl-catch-all-apply
               'vlax-get-property
               (list xlapp 'activeworkbook)
             )
             'Sheets
           )
         )
         'Item
         sh-n
       )
     )
  )
  (setq    VBProject
     (vl-catch-all-apply
       'vlax-get-property
       (list
         (vl-catch-all-apply
           'vlax-get-property
           (list xlapp
             "ActiveWorkbook"
           )
         )
         'VBProject
       )
     )
  )
  (setq    Item (vl-catch-all-apply
           'vlax-invoke-method
           (LIST
         (vl-catch-all-apply
           'vlax-get-property
           (LIST
             VBProject
             'VBComponents
           )
         )
         'Item
         sh-n
           )
         )
  )
  (vl-catch-all-apply
    'vlax-invoke-method
    (LIST
      (vl-catch-all-apply
    'vlax-get-property
    (LIST
      Item
      'CodeModule
    )
      )
      'DeleteLines
      1
      (vl-catch-all-apply
    'vlax-get-property
    (LIST
      (vl-catch-all-apply
        'vlax-get-property
        (LIST
          Item
          'CodeModule
        )
      )
      'CountOfLines
    )
      )
    )
  )                    ;删除历史的vba代码
  (vl-catch-all-apply
    'vlax-invoke-method
    (LIST
      (vl-catch-all-apply
    'vlax-get-property
    (LIST
      Item
      'CodeModule
    )
      )
      'AddFromString
      VBA-STR
    )
  )
  (vl-catch-all-apply
    'EVAL
    (list (vl-catch-all-apply 'READ (list run-str)))
  )
  (vl-catch-all-apply
    'vlax-get-property
    (LIST
      (vl-catch-all-apply
    'vlax-get-property
    (LIST
      Item
      'CodeModule
    )
      )
      'CountOfLines
    )
  )                    ;返回写入成功的行数
)

 

 

 

 

Lisp向excel注入vba代码
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|中国膜结构网|中国膜结构协会|进口膜材|国产膜材|ETFE|PVDF|PTFE|设计|施工|安装|车棚|看台|污水池|中国膜结构网_中国空间膜结构协会

GMT+8, 2024-11-1 10:25 , Processed in 0.149392 second(s), 27 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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