当前位置: 首页 > news >正文

Stata绘制分类带可信区间的折线图

论文中折线图可以表示两个变量间的变化关系,带误差或可信区间的折线图表示其中一个变量的变化范围,既往我们已经使用R语言绘制了分类带误差和可信区间的折线图,今天我们使用Stata来绘制分类带误差和可信区间的折线图。
在这里插入图片描述
继续使用我们的汽车销售数据(公众号回复:汽车销售,可以获得该数据)来演示,先导入数据,我是直接黏贴
在这里插入图片描述
我们来看下数据,car就是汽车售价,age是年龄,gender是性别,inccat是收入,这里分成4个等级,ed是教育程度。
假设想知道不同教育水平中不同性别人群购车的平均价,我们先得对数据进行整理

collapse (mean) car= car age=age,by( ed gender )

在这里插入图片描述
Collapse函数一次可以分组两个变量,但是不能出两个结果,如果你还想知道标准误的结果,只能再做一次,然后合并,这一点就比不上R了。不过也就是多做一次,也不麻烦。

collapse (semean ) se= car ,by( ed gender )

在这里插入图片描述
合并数据,其实很简单直接粘贴在Excel合并就好了。
在这里插入图片描述
把黏贴好的数据重新导入stata
在这里插入图片描述
因为我们绘制的是带可信区间的折线图,所以要先生成可信区间

g up= car+1.96* se
g lp= car-1.96* se

在这里插入图片描述
生成可信区间就可以绘图了,我们先画女性f的,这里要用lcolor控制颜色,不然后期颜色不一样

twoway(rcap up lp ed if gender=="f",lcolor(blue))

在这里插入图片描述
然后画连接线,这里我们使用mlcolor(blue)lcolor(blue)控制颜色,控制的是先得颜色和便面环的颜色,填充的颜色还没有改,所以有点怪怪的

twoway(rcap up lp ed if gender=="f",lcolor(blue))(connected car ed if gender=="f",mlcolor(blue)lcolor(blue))

在这里插入图片描述
使用mfcolor控制填充颜色

twoway(rcap up lp ed if gender=="f",lcolor(blue))(connected car ed if gender=="f",mlcolor(blue)lcolor(blue)mfcolor(blue))

在这里插入图片描述
这样一条线就画好了,我们按照刚才的方法画另一条,非常简单把

twoway(rcap up lp ed if gender=="f",lcolor(blue))(connected car ed if gender=="f",mlcolor(blue)lcolor(blue)mfcolor(blue)) (rcap up lp ed if gender=="m",lcolor(red))(connected car ed if gender=="m",mlcolor(red)lcolor(red)mfcolor(red))

在这里插入图片描述
这个图例不好看,我们关掉它,然后添加上标题

twoway(rcap up lp ed if gender=="f",lcolor(blue))(connected car ed if gender=="f",mlcolor(blue)lcolor(blue)mfcolor(blue)) (rcap up lp ed if gender=="m",lcolor(red))(connected car ed if gender=="m",mlcolor(red)lcolor(red)mfcolor(red)),legend(off) xtitle("教育程度") ytitle("汽车售价")

在这里插入图片描述
最后在修整一下就弄好了
在这里插入图片描述
如果觉得有用就分享给有需要的人吧。

相关文章:

  • 全球与中国板上芯片LED行业发展规模及投资前景预测报告2022-2028年
  • 哪里有比Excel还好用的在线表单制作工具?
  • 使用sysctl调优Linux内核
  • charles劫持修改js文件
  • 机房服务器远程维护解决方案,解决机房安全问题刚刚好
  • 俄罗斯考虑购买700亿美元的“友好”国家外汇
  • 22牛客多校4 - Task Computing(相邻贪心,推式子倒序DP)
  • LLVM学习入门(2):实现解析器 Parser 和语法树 AST
  • Spring Cloud项目(七)——使用sentinel作为熔断降级
  • 轻量应用服务器vs云服务器:区别在哪?
  • javascript中BOM对象
  • android的本地通讯录获取以及RecyclerView展示
  • 大学生任务app软件开发功能介绍
  • 3天精通Postman---动态参数amp;断言amp;CSV数据驱动amp;Mock Server
  • 【面试题】线程池
  • [ 一起学React系列 -- 8 ] React中的文件上传
  • 【5+】跨webview多页面 触发事件(二)
  • django开发-定时任务的使用
  • Docker 笔记(1):介绍、镜像、容器及其基本操作
  • Docker入门(二) - Dockerfile
  • ES6语法详解(一)
  • Linux快速配置 VIM 实现语法高亮 补全 缩进等功能
  • 从零开始学习部署
  • 服务器从安装到部署全过程(二)
  • 免费小说阅读小程序
  • 模型微调
  • 前端技术周刊 2019-01-14:客户端存储
  • 微信开源mars源码分析1—上层samples分析
  • 微信小程序上拉加载:onReachBottom详解+设置触发距离
  • 一起来学SpringBoot | 第十篇:使用Spring Cache集成Redis
  • 一天一个设计模式之JS实现——适配器模式
  • 原生JS动态加载JS、CSS文件及代码脚本
  • ### Error querying database. Cause: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException
  • #1014 : Trie树
  • (libusb) usb口自动刷新
  • (PWM呼吸灯)合泰开发板HT66F2390-----点灯大师
  • (附源码)基于SSM多源异构数据关联技术构建智能校园-计算机毕设 64366
  • (入门自用)--C++--抽象类--多态原理--虚表--1020
  • (四)库存超卖案例实战——优化redis分布式锁
  • *++p:p先自+,然后*p,最终为3 ++*p:先*p,即arr[0]=1,然后再++,最终为2 *p++:值为arr[0],即1,该语句执行完毕后,p指向arr[1]
  • *Algs4-1.5.25随机网格的倍率测试-(未读懂题)
  • *p++,*(p++),*++p,(*p)++区别?
  • .NET Standard、.NET Framework 、.NET Core三者的关系与区别?
  • .net 调用php,php 调用.net com组件 --
  • .Net中的设计模式——Factory Method模式
  • /usr/local/nginx/logs/nginx.pid failed (2: No such file or directory)
  • ::before和::after 常见的用法
  • @Mapper作用
  • [ C++ ] STL---仿函数与priority_queue
  • []AT 指令 收发短信和GPRS上网 SIM508/548
  • [BZOJ1040][P2607][ZJOI2008]骑士[树形DP+基环树]
  • [C++]运行时,如何确保一个对象是只读的
  • [CISCN2019 华东北赛区]Web2
  • [codeforces]Checkpoints
  • [ComfyUI进阶教程] animatediff视频提示词书写要点