找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 808|回复: 2

[源码] Excel工作薄保存

[复制链接]
发表于 2021-8-21 22:04:16 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
本帖最后由 dcl1214 于 2021-8-21 22:09 编辑

  1. (Defun vlxls-app-saveas
  2.        (xlapp Filename quit? lst / Rtn save kzm wjm f wb)
  3.           ;保存工作薄
  4.   (if (and xlapp
  5.      (setq wb (vl-catch-all-apply
  6.           'vlax-get-property
  7.           (list xlapp 'activeworkbook)
  8.         )
  9.      )
  10.      (not (vl-catch-all-error-p wb))
  11.       )
  12.     ()
  13.     (setq xlapp  (vl-catch-all-apply
  14.       (function (lambda () ($xlapp-New$ 0 t nil)));$xlapp-New$晓东将首尾美元符号给删除了,自己加上
  15.     )
  16.     )
  17.   )
  18.   (setq  wb (vl-catch-all-apply
  19.        'vlax-get-property
  20.        (list xlapp 'activeworkbook)
  21.      )
  22.   )
  23.   (OR (and Filename
  24.      (setq kzm (vl-filename-extension Filename))
  25.      (wcmatch kzm "[,*.xls,*.XLS,]")
  26.       )          ;扩展名
  27.       (SETQ KZM ".xls")
  28.   )
  29.   (or (and Filename
  30.      (setq wjm (vl-filename-base Filename))
  31.      (> (strlen wjm) 0)
  32.       )
  33.       (setq wjm "data")
  34.   )
  35.   (or (and Filename
  36.      (setq f (vl-filename-directory Filename))
  37.      (setq f (vl-string-right-trim "\\" f))
  38.       )
  39.       (and (setq f (getvar "dwgprefix"))
  40.      (setq f (vl-string-right-trim "\\" f))
  41.       )
  42.   )
  43.   (setq Filename (strcat f "\\" wjm kzm))
  44.   (vl-catch-all-apply
  45.     'vlax-put-property
  46.     (LIST xlapp 'DisplayAlerts :vlax-False)
  47.   )          ;保存的时候不弹出警告的窗口  
  48.   (setq  save (vl-catch-all-apply
  49.          (function (lambda ()
  50.          (vlax-invoke-method
  51.            wb      "SaveAs"     Filename
  52.            msxlc-xlNormal         ""
  53.            ""      :vlax-False  :vlax-False
  54.            nil
  55.           )
  56.        )
  57.          )
  58.        )
  59.   )
  60.   (if (vl-catch-all-error-p save)
  61.     (progn (setq save nil)
  62.      (setq Filename (vl-filename-mktemp Filename))
  63.      (setq save (vl-catch-all-apply
  64.       (function (lambda ()
  65.             (vlax-invoke-method
  66.               wb     "SaveAs"
  67.               Filename     msxlc-xlNormal
  68.               ""     ""
  69.               :vlax-False  :vlax-False
  70.               nil
  71.              )
  72.           )
  73.       )
  74.           )
  75.      )
  76.     )
  77.   )
  78.   (if quit?
  79.     (progn
  80.       (vlax-invoke-method
  81.   (vlax-get-property xlapp 'activeworkbook)
  82.   'Close
  83.       )
  84.       (vlax-invoke-method xlapp 'Quit)
  85.     )
  86.   )
  87.   (if (vl-catch-all-error-p save)
  88.     nil
  89.     (findfile Filename)
  90.   )
  91. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 756个

财富等级: 财运亨通

发表于 2021-8-22 11:55:49 | 显示全部楼层
感谢分享源码,已收藏。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-4-28 17:39 , Processed in 0.191131 second(s), 33 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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