首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

SAS-交叉表的自动输出

今天小编打算给大家分享一下SAS实现交叉表的自动输出,交叉表是临床试验编程中非常常见的一种表格的类型,实现起来的程序也还是比较简单的。...交叉表 什么样的表是交叉表呢,下面小编分享几个简单的交叉表的例子。 ? 横向 ? 纵向 嗯,上面俩种样式的交叉表也就是今天小编要分享的主要内容。程序实现的原理大致是这样的。...小编此处采用data Step中的do循环及output语句实现。 ? ▲创建框架 ? 在创建完框架数据集后,对待分析数据集进行处理,根据输入的宏变量进行自动衍生数值型组别变量,判断缺失值是否填补。...利用proc freq过程步进行计算频数,采用ods output语句将结果输出至数据集,并对数据集进行简单的处理,便于后面与前面创建的框架结构进行合并。 ? 计算频数 ?...采用proc sql将计算结果并入框架中,并对缺失结果经过填充,采用proc transpose语句对数据集进行转置。对转置后的数据集进行处理,最终生成如下结果。 ? ▲并入、转换 ?

3K64

SAS中哈希表的连接问题

在SAS中使用哈希表十分简单,你并不需要知道SAS内部是怎么实现的,只需要知道哈希表是存储在内存中的,查找是根据key值直接获得存储的地址的精确匹配。...加上使用哈希表合并数据集时不用排序的优点,在实际应用中可以极大的提高程序运行效率,尤其是数据集较大的时候。但是由于哈希表是放到内存中的,因此对内存有一定要求!...在实际应用中,我们通常会碰到要选择把哪个数据集放到哈希表中的问题。在Michele M....从这句话可以看出,将最大的数据集放到哈希表中更为高效,但是在实际应用中根据程序的目的还是需要做出选择,即选择左连接(A left join B)还是右连接(A right join B)。...其实很简单,如果数据集不是很大的时候可以这样处理:如果是左连接那么就把数据集B放到哈希表中;如果是右连接就把数据集A放到哈希表中;如果是内接连(A inner join B)那么就把大的放到哈希表中。

2.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Power Pivot中交叉构建的表

    语法 Union ( [, [, … ] ] ) 位置 参数 描述 可重复第1参数 Table 需要合并的表格 B. 返回 表——合并的表的所有行和列 C....Union('表1','表3') ? 解释:因为是根据列的位置来进行合并,所以表1的学科和表3的成绩组合在一起了,组合后系统自动判定为文本格式。 2. Except A....返回 表——左边的表去除右边表的剩余部分 C. 注意事项 只根据行来判断,如果2个表有1行是重复的,则会去掉后显示 2个表必须列数一致 2个表对比列的数据类型需一致 D....作用 表——去除重复的后的表 E. 案例 Except('表1','表2') ? Except('表2','表1') ? 相当于Power Query中的左反。 3. Intersect A....作用 返回左表和右表具有相同值的表(不去重)。 E. 案例 ? Intersect('表1','表2') ? 解释: 因为左表具有重复项,所以返回的也保留重复项。

    1.2K10

    SAS-坐标表的实现

    今天小编打算分享的是SAS中坐标表(axistable)的实现及常见用法。 生存分析图 一年前,小编分享了一篇SAS-生存曲线的绘制......,今天这篇可以看做是前文的续篇,今天主要分享的axistable的实现,当然也和生存曲线密不可分,在临床统计编程中,axistable应用最多的地方也是生存曲线。...(本文例子中数据沿用前文,可至前文查查) ? 所谓的坐标表(axistable),就是上图中No.at risk以下的部分。每一个刻度值都对应这相应的结果。...今天小编要分享的是GTL中axistable实现的方法。一共有2种方式,innermargin或者采用拼图。...innermargin 至于innermargin的方法,也是SASHELP中很容易找到的例子。见下图,是使用innermargin的方法。 ? 它会在坐标轴内生成坐标表,不能放在坐标轴外。

    3.1K00

    Python中的加权随机

    我们平时比较多会遇到的一种情景是从一堆的数据中随机选择一个, 大多数我们使用random就够了, 但是假如我们要选取的这堆数据分别有自己的权重, 也就是他们被选择的概率是不一样的, 在这种情况下, 就需要使用加权随机来处理这些数据...简单线性方法 下面是一种简单的方案, 传入权重的列表(weights), 然后会返回随机结果的索引值(index), 比如我们传入[2, 3, 5], 那么就会随机的返回0(概率0.2), 1(概率0.3...加速搜索 上面这个方法看起来非常简单, 已经可以完成我们所要的加权随机, 然是最后的这个for循环貌似有些啰嗦, Python有个内置方法bisect可以帮我们加速这一步 import random import...去掉临时变量 其实在这个方法里面totals这个数组并不是必要的, 我们调整下策略, 就可以判断出weights中的位置 def weighted_choice(weights): rnd = random.random...只不过我们把赋值临时变量的功夫省下来了, 其实如果传进来的weights是已经按照从大到小排序好的话, 速度会更快, 因为rnd递减的速度最快(先减去最大的数) 4.

    2.1K30

    Power Pivot中如何通过交叉表计算新老客户?

    ('数据表'[客户]),'数据表'[新老客户]="老客户") 注意:这里的老客户数,只能在维度筛选中无重复的情况下才能使用。...例如同一个月既是新客户,又是老客户,这个度量的老客户数就会出现多计算的现象。 所以我们可以使用总客户数-新客户数来表示老客户数。...总客户数:=DistinctCount('数据表'[客户]) 老客户数_减法:=[总客户数]-[新客户数] (三) 交叉表直接通过度量书写 我们知道之前的有分享过共享多端的1端如何进行筛选计算,这我们也可以用这种方式来计算新老客户...计算之前未购买的客户数 增加一个时间条件,可以计算出之前未购买的客户数。...,又是之前未购买的客户就是我们的新客户,然后进行计算。

    1.2K20

    SAS-2X2表,率差的输出...

    这篇接着上一篇的说(SAS-可信区间的输出...),率差的输出...为啥要分开呢,因为这样不就是显得小编勤奋高频输出吗... ? 真的是感觉太久没打理公众号,现在打算好好打理一段时间了 ?...可以输出可信区间,同样也可以输出率差,这里的率差是2*2表的率差,同样也是一个参数来控制。 计算试验组与对照组发生不良事件的率差 数据还是沿用上一篇推送的(如下) ?...那么究竟哪一个才是最开始想要计算的对照组-试验组的率差以及可信区间呢,答案是不管dif1还是dif2都是对照组-试验组的率差,但是dif1与dif2分别表示(group*aeyn)中*后面的变量(aeyn...Group*AEYN等价于AEYN*Group吗 如题所述,在率差的计算中Group*AEYN是否等价于AEYN*GROUP,答案是明显不等于的。...这个就得从2*2表的输出的结构以及率差计算的方式(第一行-第二行)来说了。先来看看下面的的图: ? ?

    3.2K30

    SAS-编程中的小技巧

    今天分享的是SAS软件使用过程的中的几个小技巧,掌握了一些小技巧,编程的效率会提高的更快,还能减少敲代码出错率,好处很多,小编就不一一赘述了。...----Setup~ 1 快捷键(功能键的使用) 今小编这里说的快捷键,并不是通俗意义上的那种CTRl+A、CTRL+C的这种快捷键,而是SAS编程里面的宏功能键(我称“快捷键”)。...01 看效果 1.以输入CSV为例 2.输入回车键 02 如何设置 1.先复制代码 2.工具--添加缩写 3.设置缩写(缩写:设置你需要的快捷方式,代码块放入缩写的插入文本中) 4.点确定就好了 小编还是忍不住要来点...2 打开SAS自动运行Macro 设置打开SAS自动调用你写好的Macro,或者打开SAS自动执行你想执行的代码。...好了,小编苦逼的操作还有能多,在SAS的路上,我觉得还是靠自己动手尝试,敢尝试,敢操作,敢犯错,才能走的更远更长,离我伪大神的道路在进一步。

    1.7K80

    SAS-编程中的小技巧

    1 快捷键(功能键的使用) 今小编这里说的快捷键,并不是通俗意义上的那种CTRl+A、CTRL+C的这种快捷键,而是SAS编程里面的宏功能键(我称“快捷键”)。...3.设置缩写(缩写:设置你需要的快捷方式,代码块放入缩写的插入文本中) ?...2 打开SAS自动运行Macro 设置打开SAS自动调用你写好的Macro,或者打开SAS自动执行你想执行的代码。...01 看如何修改 1.找到你SAS安装路径(小编的是:B:\SAS\SASFoundation\9.2(32-bit))在此目录下找到\nls文件夹(此文件夹下有:\en,\u8,\zh等文件夹,小编\...启动SAS:右键work逻辑库看属性,这个时候work逻辑库的默认储存路径就以及修改过来了 ? 今天就这么多了,贪多嚼不烂

    1.5K30

    SAS-编程中的小技巧(六)

    解决ODS输出结果弹出 前段时间有人问小编,批量执行ods输出文件时,总是弹出并打开输出的文件,有没有办法关闭呢?你是否也遇到这样的问题,而找遍ods相关的Option仍无法解决呢?...256; ods _all_ close; ods results on; %let path=C:\Users\Administrator.BF-20180423ODYZ\Desktop\微信公众号\sas...; ods _all_ close; ods results off; %let path=C:\Users\Administrator.BF-20180423ODYZ\Desktop\微信公众号\sas...大部分乱码的原因来源于数据集或与SAS版本编码的不同造成的...解决数据集乱码的办法其实还是比较多的,可以进行转码,也可以用对应编码的SAS软件进行打开...小编对编码这块没有深入的了解与研究,只谈自己解决数据集乱码的办法...,欢迎指正...当然小编觉得 很多的时候SAS能自动转码,当然如果出现乱码的情况,大概就是那种不是很多的时候被你遇到了... 1.在导入外部数据时,导入完后,发现数据集乱码....根据外部文件的编码来指定编码读入数据

    1.7K20

    SAS-编程中的小技巧(二)

    嗯,这是一篇SAS编程的中的小技巧,不知是否记得小编之前写过一篇SAS-编程中的小技巧(可点击跳转),嗯,这又是一些编程中相关的小技巧。接下来小编将一一介绍这几个小技巧。...1 Bat启动SAS 为什么要用Bat来启动SAS呢,其实这有点鸡肋,对于广大的找不到合适的SID续订的朋友,与还需要每次启动SAS还需要手动修改系统时间的朋友来说,这个Bat其实还是很方便好用的!...小编是这样认为的:当你的SAS程序已经调试好了,直接运行就能出结果的情况下,用Bat来执行程序的速度比打开SAS软件,将SAS程序拖入软件中执行的速度要快,效率要高~(这个解释是小编猜测,可能有些牵强,...其实小编也不知道为什么,因为小编基本上都是启动SAS后然后将程序拖入SAS中运行的,不过小编混迹在SAS的编程圈子里面,接触过非常多公司SAS编程的模式,几乎很多公司(临时试验相关统计部门的SAS程序)...双击修改后的快捷方式,打开SAS会自动执行指定的SAS程序。

    1.1K10

    SAS-编程中的小技巧(九)

    欢迎来到SAS程序分享号 新年的第一篇推文,一直打算写一点什么,小编辗转反侧、思来想去,发现编程中的小技巧已经写了八篇,如果在写一篇,那便是第九篇,与2019年的9有遥相呼应之势!...好像做为新年的第一篇是一件很吉祥的事情。于是,在着实没什么内容想写的情况之下,今天小编打算分享一点编程中的小技巧。 (*ESC*)很棒!...今天小编打算分享另外一种转译的方式!也就是今天要分享的(*ESC*)使用的小技巧。在ODS输出中,(*ESC*)的作用等价于escapechar=的转译符号。...如上 title1的写法等价于title2; title3的写法等价于title4; 好处 下面来说说使用(*ESC*)的好处,其实好处有很多的。小编就举一个例子吧。...RTF中的画线 上下滑线 RTF标记语言中画线的几种写法: 下滑线:\brdrb\brdrs 上滑线:\brdrt\brdrs 具体就不贴代码演示了,肚子太饿了,着急回家吃饭!

    88320

    SAS-编程中的小技巧(三)

    这又是一篇SAS编程中的小技巧,这次要说的是SAS中数据字典与Macro结合起来的使用技巧,以及数据集删除、保存等技巧.......这些表有一些小齿轮...这些表对于SAS很重要,SAS的很多属性,配置都是以表的形式储存下来...也就是储存在这样的表里面...红色部分圈起来的俩个表是比较常用的表...也是数据集字典的来源......那么为什么SAS的逻辑库名称不能超过8位的长度...大概是因为VTABLE这个表中逻辑库名称的那一列的变量长度定义的是8的原因吧...所有定义长度超过8的时候,逻辑库名称就写不进VTABLE那张表......Proc Contents 在SAS中还有另外一种获取逻辑库下所有数据集/指定数据集结构的方式...就是proc contents过程步!...快速删除数据集 经常,我们需要在SAS中删除一些数据集...那么如何删除数据集呢?删除的方法众多...来见见一些常见的方法...

    2.4K20

    SAS-编程中的小技巧(七)

    虽然难以启齿,但是花费巨额的代价买的教训,还是想分享给大家。...很多人都发现了用SAS程序语句删除的数据集,在回收站里面找不到...那就这就意味着不能用传统的回收站还原的方式来恢复误删除的SAS数据集...如果数据是没有办法溯源,是否剩下的只有是删库跑路这个选择呢呢......前几天看到有人问到相关问题,觉得还算不错,于是就尝试了如何去恢复用SAS语句删除的数据集......具体方式如下..奥,顺带提一下异常关闭SAS后程序如何找回请点击:SAS-编程中的小技巧(四) libname test "C:\Users\Administrator.BF-20180423ODYZ\...尽管update语句与merge有惊人的相似 但是依旧有一些不同的之处... 比如,如果数据集观测出现多对一的情况 是会报出绿色的warning ?

    91040

    SAS-编程中的小技巧(四)

    我们在使用的SAS的过程中,把SAS给玩崩了的是常常遇到的事,有些时候,我们写的程序忘记了保存,就会导致之前的写的代码付诸东流...那么该如何避免呢,那么SAS是否有自动保存代码的功能是呢?...按照上面的设置,程序就可以缩短程序自动保存的时间了...那么这样设置后就会发现即使我等了一分钟,我们操作的那个程序XXX.sas* 的上那个*还没有消失,这就表示程序并没有正的保存...那么SAS所谓的自动保存是啥意思呢...SAS英文版本乱码问题 在使用英文版本的SAS时候,有人会遇到程序里面包含中文乱码的问题...这个问题小编也不是太清楚,大概是你打开的英文版本的SAS不支持中文编码的识别吧...当然网络上出现一些修改CFG...,小编觉得其实这些操作的本质就是修改成DBCS版本的中的CFG..其实可以直接将DBCS中的CFG替换到英文版本.....或者直接用DBCS版本的英文版本...当然如果你英文好,且只做国外的项目的,所有注释全英文写...\SASFoundation\9.4\nls\en\sasv9.cfg" /*英文版本配置文件的路径*/ 凑字数 内容好像有点少哎,为了凑一凑字数在来一点代码吧...在SAS编程中,经常会遇到重复的记录该如何去重

    1.4K20

    SAS-编程中的小技巧(八)

    很久没写公众号了...也积累很多想要分享的小技巧,奈何一直苦于工作繁忙,诸事繁多无暇分身...在即将要忘掉所有想分享的小技巧的前一秒想起了公众号还没写呢...最近一直在写报告,用SAS输出RTF,所有啊...我们在使用RTF输出统计报告的时候,SAS默认输出的纸张方向是纵向的。当然我们都知道可以使用option选项来进行设置。...上面那段代码效果如下(纵-横-纵),所以SAS是可以实现输出同一RTF文件,控制不同表格的纸张方向.... ?...RTF输出标题级别的设置 很多人都喜欢,应该是很多公司的模版的都喜欢将表格的标题通过report中的compute before _page_ 添加到table的前面,但是这种方式并不能直接定义标题的级别...我们可以使用\outlinelevel2{表1.1 Class数据集}\line 进行标题的的设置,level2表示的是二级标题,这个2可以改成1-n的数字,当然1-9小编是知道可以的,至于9后面的小编就没试过

    1.5K30
    领券