3

我正在使用 SAS STP 创建报告,我想在报告上显示图像(徽标)。好的,这就是正在发生的事情:

data _null_;
    file _webout;
    put '<html>';
    put '</html>';
run;

我正在 PUTing HTML,因为我有需要显示的复杂表格格式并且我没有使用%STPBEGIN&%STPEND因为这会打开一个 ODS 流,坦率地说我不知道​​如何处理并且我遇到了问题。不使用%STPBEGIN意味着上面的代码。这对我来说是一个非常成功的机制。我可以用 CSS 和所有东西展示漂亮的报告。唯一的问题是图像。一位客户最近要求在每份报告上加上徽标。我虽然这很容易,但事实并非如此。好的,这是交易,我尝试使用<img src=" "/ >标签,我想我会使用一些相对路径,我的图像会显示。这种技术成功了也失败了。

  • 我使用 SAS Management Console 将图像添加到文件夹位置并使用其相对路径“/Products/SAS Enterprise GRC/****”(不起作用)
  • 我将图像复制到 Web/Staging/*** 下的默认主题的图像文件夹中,并尝试使用相对路径(不起作用)。所以我尝试使用默认主题中的其他图像。有效。

我被卡住了,如何在这里使用自定义图像?

4

4 回答 4

3

如果您的图像是静态的,您可以使用数据步将其嵌入到您的结果中,而无需将文件复制到服务器。

<img src="" />这样做的技巧是将图像编码为 Base64 编码,然后您可以使用以下神奇的符号将图像嵌入到语句中:

<img src="data:image/png;base64,...." />

您可以看到该src=属性包含元数据以告诉浏览器该值包含图像数据,表示一个 png 文件(我在测试这篇文章时使用了一个 png 文件,您可能有一个 JPG/BMP 等...)并且值使用 base64 编码。最后的 4 个句点将替换为以 base64 表示法表示的图像数据。这看起来像这样:

<img src=" ... much much more base64 content here ... HSLyz+h9xy+7HbHRL83L1tv9h8+4d/+Ic/Gf8DiYav3mpqHAMAAAAASUVORK5CYII=" />

将图像转换为 base64 很简单。您可以简单地在 Google 上搜索“在线 base64 图像转换器”,例如这个。拖放您的图像,它将为您生成 base64 代码。

要将其放入 sas 中的数据步,这只是以下情况:

data _null_;
    file _webout;
    put '<html>';
    put '<img src="......etc..." />';
    put '</html>';
run;

如果您的图像特别大(例如大于 ~32k),您可能会在尝试从数据步输出它时遇到问题。我可能需要对此进行测试以澄清。您可以通过从 SAS 中的文件读取 base64 图像并将其直接流式传输到 来解决此问题_webout,使用类似于以下的代码:

data _null_;
  file _webout;
  infile '\path\to\base64\file.ext';
  input;
  put _infile_;
run;

如果您想变得非常棘手,您可以拍摄任何您喜欢的图像(例如在 SAS 中生成的图表)并将其动态转换为 base64,然后将其流式传输。这是一些 SAS 代码,它将获取图像文件并将其转换为 Base64:

data _null_;
  length base64_format $20 base64_string $32767;

  infile "\your_sasdir\hi.png" recfm=n;
  file "\your_sasdir\hi.base64";
  input byte $16000. ;

  * FORMAT LENGTH NEEDS TO BE 4n/3 ROUNDED UP TO NEAREST MULTIPLE OF 4;
  format_length = 4*(lengthn(byte)/3);
  mod = mod(format_length,4);
  if mod ne 0 then do;
    format_length = format_length - mod + 4;
  end;
  base64_format = cats("$base64x",format_length,".");

  base64_string = putc(cats(byte), base64_format);
  put base64_string;
run;

这是我用来测试的图像:

在此处输入图像描述

转换后,Base64 表示应如下所示:

iVBORw0KGgoAAAANSUhEUgAAABQAAAAUCAIAAAAC64paAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAABaSURBVDhP5YxbCsAgDAS9/6XTvJTWNUSIX3ZAYXcdGxW4QW6Khw42Axne81LG0shlRvVVLyeTI2aZ2fcPyXwPdBI8B999NK/gKTaGyxaMX8gTJRkpyREFmegBTt8lFJjOey0AAAAASUVORK5CYII=

我将看看我是否能找到一种方法来简化它,因为这是我们在工作中经常做的事情。


编辑: 有趣的是,SAS9.4 似乎支持直接ODS HTML5与该inline选项一起使用。请参阅此处的文档。

另请参阅Don Henderson 的这篇文章,它提供了一种类似的方法来解决这个问题。感谢 Vasilij 提供的链接。

于 2016-01-11T23:02:19.283 回答
0

当您在 SAS 元数据中定义图片时,可以通过 SAS 内容服务器对其进行访问。要获取图片 URL,请登录:“ https://severhost/SASContentServer/repository/default/sasfolders ”并搜索您的图片。

如果您在目录 /Products/SAS Enterprise GRC/PictureName.gif 中定义了您的图片,它应该可以从地址访问https://severhost/SASContentServer/repository/default/sasfolders/Products/SAS Enterprise GRC/PictureName.gif(Report )'

当然,您必须记住,客户用户需要在 SAS 元数据中具有访问权限才能读取图片对象。

如果这不能解决您的问题,请输入您使用的 SAS 软件版本。

于 2016-01-10T20:20:30.977 回答
0

我曾经和你有过类似的问题。我已将图像添加到我们的 Intranet,当时恰好是 SharePoint。我将该图像定义为具有公共访问级别,然后在我的所有报告中引用。

由于该报告仅针对内部受众,因此他们都可以访问 Intranet,但不一定可以访问 Content Server,因此它规避了 Bagin 提到的问题。

如果您没有合适的 Intranet,您始终可以从您的公共网站引用一个徽标,该徽标可能可供所有观众使用,即使他们是外部观众,但您无法控制该徽标文件,总有一天它可能会以某种不受欢迎的方式发生变化。

问候, 瓦西里

于 2016-01-11T09:49:44.763 回答
0

使用SASjs,您可以将任何二进制内容编译成 SAS Web 服务(存储过程或 Viya 作业)。

这是一个使用 MP3 文件的示例: https ://github.com/allanbowe/sasrap

于 2022-01-09T13:17:16.490 回答