【问题标题】:How to write Unix Sas result into a specific range in Excel如何将 Unix Sas 结果写入 Excel 中的特定范围
【发布时间】:2016-12-01 18:25:29
【问题描述】:

我在 Unix 上安装了 SAS(不是在 PC 上),我想创建一个 excel 模板,将其上传到 Unix 并让 SAS 将值写入特定和预格式化的范围/单元格。我该怎么做?

我认为 DDE(动态数据交换)或 Excel libname 引擎不会起作用,因为这两种方法无法与本地 PC 应用程序 (Excel.exe) 通信。但是,ODS 和 proc 导出并不能真正控制 SAS 应该将输出导出到哪个单元。这个问题有解决办法吗?

提前致谢!

【问题讨论】:

  • 我认为 libname XLSX 适用于 Unix 和最新版本的 SAS。但不确定它是否支持使用模板或特定范围。

标签: excel sas


【解决方案1】:

如果我是您,我会将您的 SAS 代码编写为存储过程,它将您的数据以制表符分隔格式输出到 _webout 文件引用,然后使用 VBA 从 Excel 将其作为 Web 查询调用。您可以更好地控制工作簿中填充的内容,并且不会出现 unix 兼容性问题。您可以查看此方法的指南here

【讨论】:

  • 感谢您的建议
【解决方案2】:

如果我要使用模板路径(如果我可以避免它,我不会这样做),我会这样做的方式是将模板作为数据集读入 SAS。一旦它是一个数据集,您可以根据需要填充单元格(通过 SAS 合并/更新/其他),然后导出填充的模板。然后,您将在 Windows 领域使用 VBA 或类似工具来完成任何格式化。

不过,更好的是使用 ODS EXCEL 并在那里进行格式化。

【讨论】:

  • 感谢您的回答
猜你喜欢
  • 2021-06-07
  • 2018-03-03
  • 2016-08-20
  • 2016-04-27
  • 2022-08-12
  • 1970-01-01
  • 2015-05-22
  • 2021-01-19
  • 1970-01-01
相关资源
最近更新 更多