楼主: tj0412ymy
13950 14

[原创博文] 【转】SAS的字典数据表(Dictionary table)的应用 [推广有奖]

  • 2关注
  • 48粉丝

副教授

65%

还不是VIP/贵宾

-

威望
0
论坛币
11510 个
通用积分
12.6975
学术水平
72 点
热心指数
91 点
信用等级
64 点
经验
29292 点
帖子
545
精华
0
在线时间
1203 小时
注册时间
2009-3-10
最后登录
2024-2-15

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币

版权声明:转载时请以超链接形式标明文章原始出处和作者信息及本声明
http://logistic.blogbus.com/logs/73399856.html

Dictionary table的两种访问方法:
1.直接用SQL语句访问Dictionary table
2.访问SAShelp View

    打开explorer window,在SASHELP这个library下,以V开头的视图实际上是Dictionary table内容的复制。如
proc sql;describe view sashelp.voption;quit;
   可以看到voption这个视图的内容来自dictionary.options。
   而对于View,除了SQL,直接用data步或proc步都可以访问。如
data test2;
set sashelp.vcolumn;
where libname="WORK" and memname="TEST";
run;

或者
proc contents data=sashelp.voption;
run;

或者在command栏输入viewtable sashelp.voption
Dictionary table的最常见的几个应用:
一、取出数据集的变量数和观测数
proc sql;
select nobs,nvar
into:nobs,:nvar
from dictionary.tables
where libname="WORK" and memname="TEST";
quit;
   
二、取出某一数据集的所有变量名
proc sql;
select name into :varlist
separated by " "
from dictionary.columns
where libname="WORK" and memname="TEST";
quit;
%put &varlist.;
三、取出某个library下所有数据集名
proc sql;
select memname into :dsname
separated by " "
from dictionary.tables
where libname="WORK";
quit;
四、取出所有的宏变量名
proc sql noprint;
create table macv as
select name
from dictionary.macros
where offset=0 and scope="GLOBAL";
quit;
效果同 %put _global_;
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:Dictionary Table sas的 ABLE CTI describe library window 数据表 超链接

已有 1 人评分学术水平 热心指数 收起 理由
lance0108 + 1 + 1 精彩帖子

总评分: 学术水平 + 1  热心指数 + 1   查看全部评分

本帖被以下文库推荐

沙发
r9205009 发表于 2012-5-11 23:07:09 |只看作者 |坛友微信交流群
兩情若是久長時,又豈在朝朝暮暮

使用道具

藤椅
乾坤神龙 发表于 2012-5-14 10:39:51 |只看作者 |坛友微信交流群
不错,喜欢!!

使用道具

板凳
goldbaodi 发表于 2012-5-15 00:54:04 |只看作者 |坛友微信交流群
[GOOD ..........]

使用道具

报纸
lifemg 发表于 2012-5-19 21:50:06 |只看作者 |坛友微信交流群
学习了 ,但是不懂“:”是什么意思哎

使用道具

地板
tj0412ymy 发表于 2012-5-19 21:54:03 |只看作者 |坛友微信交流群
lifemg 发表于 2012-5-19 21:50
学习了 ,但是不懂“:”是什么意思哎
在SQL中定义宏变量
对SAS和统计方面感兴趣的朋友,请加SAS学习和认证讨论群:169157207。欢迎在群上讨论!

使用道具

7
lifemg 发表于 2012-5-19 22:01:06 |只看作者 |坛友微信交流群
楼主在的啊,顺便还请教个:
proc sql;
select nobs,nvar
into:nobs,:nvar
from dictionary.tables
where libname="WORK" and memname="TEST";
quit;   

在这个程序倒数第二句,libname 和memname 是指的需要取出观测的library和数据集哇?
这个程序运行不出结果呢?

使用道具

8
tj0412ymy 发表于 2012-5-19 22:26:04 |只看作者 |坛友微信交流群
lifemg 发表于 2012-5-19 22:01
楼主在的啊,顺便还请教个:
proc sql;
select nobs,nvar
Right. It works.
  1. data test;
  2. x=1;
  3. run;
  4. proc sql;
  5. select nobs,nvar
  6. into:nobs,:nvar
  7. from dictionary.tables
  8. where libname="WORK" and memname="TEST";
  9. quit;   
复制代码
对SAS和统计方面感兴趣的朋友,请加SAS学习和认证讨论群:169157207。欢迎在群上讨论!

使用道具

9
lifemg 发表于 2012-5-20 10:31:45 |只看作者 |坛友微信交流群
哦 谢谢楼主哎 可能是我取的数据库及数据集有问题哈

使用道具

10
mccinfo 发表于 2012-5-20 11:32:55 |只看作者 |坛友微信交流群
学习了~

使用道具

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-4-26 13:12