0

我正在使用该split命令拆分一个变量,该变量具有多个用分号分隔的字符串。我还想跟踪由于拆分原始字符串变量并将其存储在本地宏中而创建了多少新字符串变量。

例如,如果我的初始数据类似于:

State

PA;CA
MA
WA;CA;OR

我使用split State, p(;)

State     State1 State2 State3

PA;CA      PA     CA
MA         MA
WA;CA;OR   WA     CA     OR

我希望能够发现它已经创建了3新变量并将该值存储在本地宏中。

有没有办法做到这一点?

4

2 回答 2

1

更一般地,您可以使用以下ds命令:

clear

input str10 State
"PA;CA"
"MA"
"WA;CA;OR"
end

split State, p(;)
drop State

ds State*
State1  State2  State3

return list

macros:
            r(varlist) : "State1 State2 State3"

local states : word count `r(varlist)'
display `states'
3

显然,在此之后执行此split操作是不必要的。

于 2018-09-07T20:57:44.253 回答
0

许多 Stata 命令会留下有用的对象,split也不例外。

从帮助文件(您可以通过键入 找到help split):

Stored results

    split stores the following in r():

    Scalars   
      r(nvars)       number of new variables created
      r(varlist)     names of newly created variables

这些可以像这样使用:

clear

input str11 states
"PA;CA"
"MA"
"WA;CA;OR;PA"
end

compress
split states, parse(;) gen(S)

display `: word count `r(varlist)''
display r(nvars)

第二个可能更容易。

于 2018-09-07T20:54:35.567 回答