楼主: gshdsl2017
5074 3

[中国统计年鉴] stata如何识别第二个最大值 [推广有奖]

  • 2关注
  • 0粉丝

已卖:2份资源

硕士生

78%

还不是VIP/贵宾

-

威望
0
论坛币
682 个
通用积分
0.0000
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
573 点
帖子
51
精华
0
在线时间
339 小时
注册时间
2017-11-3
最后登录
2024-2-16

楼主
gshdsl2017 发表于 2017-11-10 15:57:37 来自手机 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
a,b,c两列数据,a为不同地区,b为民族,c为不同地区下的不同民族人口总数。我想生成一个变量为c中第二大民族人口数,max命令只能找到最大的第一位
二维码

扫码加我 拉你入群

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

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

关键词:Stata tata 最大值 不同地区 人口总数

回帖推荐

jiuxun 发表于2楼  查看完整内容

你生成一个变量,为最大值,然后把原来变量里和最大值相等的值替换为缺省值,再用max命令对经过处理的这个变量,得到的就是第二大的值啦 gen v1=max(c) replace c=. if c==v1 gen v2=max(c) label var v2 "你要的第二大的数" 或者简单方法 sum c //看max这项,然后假设这个样本的值可能是123400个人 sum c if c
已有 1 人评分经验 收起 理由
remlus + 100 精彩帖子

总评分: 经验 + 100   查看全部评分

沙发
jiuxun 发表于 2017-11-10 21:50:47
你生成一个变量,为最大值,然后把原来变量里和最大值相等的值替换为缺省值,再用max命令对经过处理的这个变量,得到的就是第二大的值啦
gen v1=max(c)
replace c=. if c==v1
gen v2=max(c)
label  var v2 "你要的第二大的数"
或者简单方法
sum c
//看max这项,然后假设这个样本的值可能是123400个人
sum c if c<123400
//再手动看max这项,此时的最大值就是人口第二大的民族对应的人数,假设是123000个人
list if c==123000
//看到的这条记录就是人口第二大的民族
已有 2 人评分经验 论坛币 学术水平 热心指数 收起 理由
remlus + 100 精彩帖子
admin_kefu + 20 + 20 + 2 + 2 热心帮助其他会员

总评分: 经验 + 120  论坛币 + 20  学术水平 + 2  热心指数 + 2   查看全部评分

藤椅
北纬34° 发表于 2021-3-23 22:31:36 来自手机
jiuxun 发表于 2017-11-10 21:50
你生成一个变量,为最大值,然后把原来变量里和最大值相等的值替换为缺省值,再用max命令对经过处理的这个变 ...
谢谢你

板凳
scx980087 发表于 2021-8-14 11:47:30
jiuxun 发表于 2017-11-10 21:50
你生成一个变量,为最大值,然后把原来变量里和最大值相等的值替换为缺省值,再用max命令对经过处理的这个变 ...
感谢!棒

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

本版微信群
扫码
拉您进交流群
GMT+8, 2026-1-18 01:28