- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这是一个反射(reflect)所取得的一些进展的编辑:
我有以下功能:
proc fcmp outlib=mydir;
function sqlWhere(interval $, myDate $) $;
...
return("id");
endsub;
quit;
这已经过测试并且工作正常。所以我尝试了:
%macro sqlWhere(interval, myDate);
&interval.("year") AS t
&myDate.("someDateField") AS tt
%mend;
proc sql;
CREATE TABLE test AS (
SELECT %sqlWhere(t, tt)
FROM myTable);
quit;
当我运行选择时,顶部运行正常。但是,proc sql 爆炸并说我缺少逗号。我很困惑,因为该函数在其他应该使代码工作的测试中返回“id ”。该错误表明“tt”部分缺少逗号...
我正在尝试在 SAS 中进行动态查询。我有几个问题,我不确定我想做的事情是否可行。另外,很抱歉删除了先前的问题;我想给出更好的解释。
假设我有这段代码:
proc sql;
SELECT
YEAR(myDate) AS yr,
MONTH(myDate) AS mo,
id
FROM
myTable;
run;
我试图让它成为有条件的。这带来了两个问题。首先,我无法使用基本语法。其次,我无法让我的自定义函数创建正确的字符串。
我想要这样的东西:
%let a = sqlDate("month");
proc sql;
SELECT
&a
FROM
myTable;
run;
这个结构不起作用,即使我放弃这个功能而只是输入
%let a = "YEAR(myDate) AS yr, MONTH(myMonth) AS mo, id";
这样的事情可能吗?
我的第二个问题是如何构造函数本身,但我想先确认一下我什至可以做这样的事情。我基本上是在主程序中放置一个指示器,它可以是“天”、“周”、“月”或“年”,然后告诉程序以给定的方式查询 SQL。我可以通过某种方式传递整个字符串吗?是否可以以这种方式基于输入构建字符串?
最佳答案
您的第一个问题是由对 SAS 宏的误解解释的。当你把这个:
%let a = "YEAR(myDate) AS yr, MONTH(myMonth) AS mo, id";
SAS 将输入您的查询:
"YEAR(myDate) AS yr, MONTH(myMonth) AS mo, id"
即:它将保留引号。如果你想在将它放入 SAS 宏变量时“隐藏”函数之类的东西,你必须使用 %str() 函数而不是“或”。所以如果你会写:
%str(YEAR(myDate) AS yr, MONTH(myMonth) AS mo, id);
你会有一些有用的东西。
回答你的第二个问题:这当然是可能的。但请记住一些非常重要的事情:任何宏函数、宏变量定义或对开放代码中的宏变量的调用,都会在 SAS 代码运行之前被解释和替换。如果您的宏变量/函数依赖于 SAS 数据步骤或过程的结果,则需要将其封装在宏函数中:其中的所有内容仅在运行时解释和替换。
编辑回答您的评论:这主要是我传递的一般性建议,因为您似乎不熟悉 SAS 宏。在某些情况下,您会得到奇怪的结果,看起来您的宏变量没有设置/更改,如果您没有意识到这一点,可能会令人沮丧。 (我们都是第一次遇到它;))
In your specific case, if we assume you have made an sqldate macro that returns the appropriate select part, you're probably best off putting it immediately into the query.例如:
%macro sqldate(period);
&period.(mydate) as period
%mend;
/*note no semicolon, since a macro function is basically the same as saying: resolve this piece of macro code and add the result directly to my written code.*/
proc sql;
select %sqldate(month)
from mytable;
quit;
/*also note: you end proc sql with a quit statement instead of run*/
关于sql - 在 SAS Proc Sql 中进行动态 SQL 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17624273/
在经历了DDOS攻击后,不知何故/proc/kcore非常巨大,我使用一个小的php类来检查当前的磁盘空间,以及已经使用了多少。 它显示以下内容: Total Disk Space: 39.2 GB
所以我从 ruby 移植了一个工具,可以在对象上定义回调 block ,我希望在设置回调的情况下调用它。所以基本上是这样的。 def set_block(&block) @new_kid_on
我定义了两个脚本:第一个脚本调用第二个脚本中的 proc。第二个脚本定义了一个命名空间 fooSpace , 定义了一个变量 fooValue内fooSpace , 并定义了一个过程 myProc内f
使用一个 proc 时,我的脚本工作正常(检索 sftp 提示)。但是当我尝试在 proc 中使用 proc 时,脚本卡住了,我不知道为什么。 请不要重构代码,这不是重点,我需要了解这里的问题。 工作
我想知道是否有一种方法可以识别某些proc文件中用于DMA映射的内存,例如mtrr和iomem,或者通过lspic -vv . 在我的/proc/mtrr中,只有一个无法缓存区域,它似乎几乎指向3.5
我有 2 个过程,它们一个接一个地调用。第一个过程使用 diff 功能并创建 file.txt。压缩文件后的过程。问题是当我运行脚本时,file.txt 是空的。当我注释掉压缩过程时,文件中打印了差异
我曾经认为 /proc/self 和 /proc/$$ 在 bash 终端中是一样的,但现在我发现它们是不同的。 我知道$$是当前进程的pid,/proc/self是当前运行的进程,应该是bash终端
在下面的程序中,我想在第 2 个过程中捕获数据包,而 ping 在第 1 个过程中运行。现在,如果我执行这个程序,proc 正在运行 ping 并退出它。有解决此问题的想法吗? 我的 TCL 代码:
在 proc 中,您可以获得 proc 名称(无需对其进行硬编码)吗?例如 proc my_proc { some_arg } { puts "entering proc [some way
我有一个自定义的 A10 存储库,我试图在其中创建一个能够读取 /proc/[pid]/some-file 的应用程序文件,例如stat和 status ,有点像 ps做。 看完这篇 answer很明
我是 TCL 的新人。我通过 Windows Vista 下的 DOS 窗口“tclsh85 FOD/Scripts/program1.tcl”执行 TCL 代码。 program1.tcl 包含“s
我想查看每个进程的精确内存量用作匿名页,因为匿名内存不能调出,因此精确跟踪此使用情况非常重要。 获取匿名页面总数的一种方法是读取/proc/meminfo AnonPages。 另一种方法是将 sma
在 Ruby 中,Proc.new { 'waffles' } 和 proc { 'waffles' } 之间有什么区别吗?我发现很少有人提到第二种语法。 使用 irb 进行测试,我没有发现任何明显的
我正在寻找有关Linux系统上/proc/net/nf_conntrack和/或/proc/net/ip_contrack文件内容的详细文档。 是的,我知道,有许多实用程序可以用人类可读的格式向我显示
而不是执行多个单独的 PROC FREQ一个非常大的数据集上的程序,我想通过执行单个 PROC FREQ 来提高效率与多个 TABLE声明。我们的 QA 流程需要表格标题,这很简单,只需一个 TABL
我想在 /proc/driver 下创建一个文件目录。我想使用像 proc_root_driver 这样的宏(或提供的其他东西)而不是明确使用“驱动程序/模块名称”。我用 create_proc_en
在 SQL Server 2005 中,我希望名为 LimitedUser 的用户只能运行一个过程: GRANT EXEC ON [usp_RunETL] TO [LimitedUser] 但是,该
考虑到以下两个过程: proc firstOne(): void = echo "X" proc secondOne(): void = echo "X" discard 它们
我想使用 PROC TABULATE 复制 PROC MEANS 的输出。原因是我希望将利润百分比(或利润率)作为 PROC MEANS 输出中的变量之一,但希望抑制一个或多个统计数据的计算,即会有一
我的目标是使数据适合具有正支持的任何分布。 (威 bool (2p)、 Gamma (2p)、帕累托 (2p)、对数正态 (2p)、指数 (1P))。第一次尝试,我使用了 proc univariat
我是一名优秀的程序员,十分优秀!