首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >将行对转换为单行

将行对转换为单行
EN

Stack Overflow用户
提问于 2015-07-07 03:56:15
回答 2查看 79关注 0票数 1

我有张像这样的桌子

代码语言:javascript
运行
复制
|=========|=====|==================|==============|===========|===========|
| PREFIX  | ID  | PREVIOUS_PREFIX  | PREVIOUS_ID  | VENDOR_1  | VENDOR_2  |
|=========|=====|==================|==============|===========|===========|
| A       | 1   |                  |              | JAC       |      BOA  |
|---------|-----|------------------|--------------|-----------|-----------|
| B       | 2   | C                | 99           | LCH       |      GS   |
|---------|-----|------------------|--------------|-----------|-----------|
| B       | 3   | C                | 99           | LCH       |      JPM  |
|---------|-----|------------------|--------------|-----------|-----------|

我需要把它变成这样的桌子

代码语言:javascript
运行
复制
|=========|=====|==================|==============|===========|===========|
| PREFIX  | ID  | PREVIOUS_PREFIX  | PREVIOUS_ID  | VENDOR_1  | VENDOR_2  |
|=========|=====|==================|==============|===========|===========|
| A       | 1   |                  |              | JAC       |      BOA  |
|---------|-----|------------------|--------------|-----------|-----------|
| C       | 99  |                  |              | GS        |      JPM  |
|---------|-----|------------------|--------------|-----------|-----------|

这就是:

  1. 对于没有PREVIOUS_PREFIXPREVIOUS_ID的行,它将该行保留为
  2. 用于使用PREVIOUS_PREFIXPREVIOUS_ID的行:
    1. 它创建了一个新行,其PREFIXPREVIOUS_PREFIX相同,IDPREVIOUS_ID相同,VENDOR_1VENDOR_2是原始行不常见的供应商。
    2. 它删除原始行对。

EN

回答 2

Stack Overflow用户

发布于 2015-07-07 06:02:03

代码语言:javascript
运行
复制
/* Create sample data */
data have;
    input Prefix $ ID Previous_Prefix $ Previous_ID Vendor_1 $ Vendor_2 $;
    cards;
A 1  .  .  JAC BOA
B 2  C  99 LCH GS
B 3  C  99 LCH JPM
E 5  F  52 LOK U
E 5  F  52 LOK M
    ;;;
run;

/* Assign new values for Prefix & ID */
data want;
    set have;
    if Previous_Prefix ne '' then do;
        Prefix = Previous_Prefix;
        Previous_Prefix = '';
    end;
    if Previous_ID ne . then do;
        ID = Previous_ID;
        Previous_ID = .;
    end;
run;

/* Merge Vendor_1 & Vender2 into one column */
data want2;
    set want;
    if first.ID then n = 0;
    n + 1;
    by ID notsorted;
run;

proc transpose data=want2 out=want3(drop=n _NAME_ rename=(COL1=Vendor));
    by Prefix ID n Previous_Prefix Previous_ID;
    var Vendor_1 Vendor_2;
run;

/* Delete common Vendor_ */
proc sort data=want3;by Prefix ID Previous_Prefix Previous_ID Vendor;run;

proc summary data=want3;
    output out=want4(where=(_freq_ = 1));
    by Prefix ID Previous_Prefix Previous_ID Vendor notsorted;
run;

/* Transpose data from long back to wide */
proc transpose data=want4 out=want5(drop=_:) prefix=Vendor_;
    var Vendor;
    by Prefix ID Previous_Prefix Previous_ID notsorted;
run;
票数 0
EN

Stack Overflow用户

发布于 2015-07-07 06:44:25

一个稍微简单的解决方案是将单个观察扩展为2个观察,并将供应商合并到单变量中,并将previous_prefix和前缀合并到一起,以获得new_prefix和类似的id。按此顺序获取数据可以解决单个sql中的问题。看看这个草案代码。

代码语言:javascript
运行
复制
DATA WANT;
SET HAVE;
  PREFIX_NEW =COALESCEC(PREVIOUS_PREFIX,PREFIX);
  ID_NEW     =COALESCEC(PREVIOUS_ID    ,ID);
IF NOT MISSING(VENDOR_1) THEN VENDOR=VENDOR_1; 
OUTPUT;
IF NOT MISSING(VENDOR_2) THEN VENDOR=VENDOR_2; 
OUTPUT;
RUN;

PROC SQL;
SELECT PREFIX_NEW
     , ID_NEW
     , MIN(VENDOR) AS VENDOR_1
     , MAX(VENDOR) AS VENDOR_2
FROM ( SELECT PREFIX_NEW
            , ID_NEW
            , VENDOR
            , COUNT(*) AS COUNTER
         FROM WANT
         GROUP BY 1,2,3
         HAVING COUNTER=1
      )
;
QUIT;

希望这会有帮助!

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31259475

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档