挚友02 发表于 7 天前

“实参太少”是怎么回事?

(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))
页: [1]
查看完整版本: “实参太少”是怎么回事?