找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 49|回复: 0

[求助] “实参太少”是怎么回事?

[复制链接]
发表于 6 天前 | 显示全部楼层 |阅读模式

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

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

×
(defun c:ReadExcelColumn (/ excelApp workBook workSheet filePath 目标列 列数据)
  (VL-load-com)
    ; ===================== 1. 必改参数(仅需修改这2行)=====================
    (setq filePath "D:\\Test.xlsx" ; ??  Excel文件完整路径(双反斜杠!)
          目标列 "A"               ; 要读取的列("A"/"B" 或 1/2/3)
          )

    ; ===================== 2. 启动Excel =====================
    (setq excelApp (vlax-create-object "Excel.Application"))
    (if (not excelApp)
        (progn (alert "无法启动Excel!请确保已安装Excel。") (exit))
    )

    ; 后台运行,禁用警告
    (vlax-put-property excelApp 'Visible :vlax-false)
    (vlax-put-property excelApp 'DisplayAlerts :vlax-false)

    ; ===================== 3. 打开工作簿(核心修复:传递路径参数)=====================
    ; 关键:'Open 后面必须跟文件路径(filePath),这是必填参数
    (setq workBook (vlax-invoke-method (vlax-get-property excelApp 'Workbooks) 'Open filePath))

    ; ===================== 4. 定位工作表(默认Sheet1)=====================
    (setq workSheet (vlax-invoke-method workBook 'Worksheets "Sheet1"))

    ; ===================== 5. 读取指定列数据 =====================
    (setq 列索引 (if (numberp 目标列) 目标列 (vlax-invoke-method workSheet 'Columns 目标列 'Column))
          最后行 (vlax-get-property (vlax-invoke-method (vlax-invoke-method workSheet 'Columns 列索引) 'Find "*" nil nil nil :vlax-true) 'Row)
          数据区域 (vlax-invoke-method workSheet 'Range (vlax-invoke-method workSheet 'Cells 1 列索引) (vlax-invoke-method workSheet 'Cells 最后行 列索引))
          原始数据 (vlax-get-property 数据区域 'Value)
          列数据 nil
          )

    ; 转换为VLISP一维列表
    (if (vlax-safearray-p 原始数据)
        (progn
            (setq i 1)
            (while (<= i 最后行)
                (setq 列数据 (cons (vlax-safearray-get-element 原始数据 i 1) 列数据))
                (setq i (1+ i))
            )
            (setq 列数据 (reverse 列数据))
        )
        (setq 列数据 (list 原始数据))
    )

    ; ===================== 6. 关闭Excel并释放资源 =====================
    (vlax-invoke-method workBook 'Close)
    (vlax-release-object 数据区域)
    (vlax-release-object workSheet)
    (vlax-release-object workBook)
    (vlax-release-object excelApp)

    ; ===================== 7. 显示结果 =====================
    (alert (strcat "提取成功!\n文件:" filePath "\n列:" 目标列 "\n数据:\n" (vl-prin1-to-string 列数据)))
    (princ)
)

我在网上摘录了这段程序,可在这报错,“实参太少”是怎么回事?
(setq workBook (vlax-invoke-method (vlax-get-property excelApp 'Workbooks) 'Open filePath))
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2025-11-26 10:34 , Processed in 0.371629 second(s), 28 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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