用ggplot2画的常用K线图
发布:cheetahfly | 分类:考研
关于本站
人大经济论坛-经管之家:分享大学、考研、论文、会计、留学、数据、经济学、金融学、管理学、统计学、博弈论、统计年鉴、行业分析包括等相关资源。
经管之家是国内活跃的在线教育咨询平台!
经管之家新媒体交易平台
提供"微信号、微博、抖音、快手、头条、小红书、百家号、企鹅号、UC号、一点资讯"等虚拟账号交易,真正实现买卖双方的共赢。【请点击这里访问】
期刊
- 期刊库 | 马上cssci就要更新 ...
- 期刊库 | 【独家发布】《财 ...
- 期刊库 | 【独家发布】“我 ...
- 期刊库 | 【独家发布】“我 ...
- 期刊库 | 【独家发布】国家 ...
- 期刊库 | 请问Management S ...
- 期刊库 | 英文期刊库
- 核心期刊 | 歧路彷徨:核心期 ...
TOP热门关键词
首先,为什么要用ggplot2来画K线图,不是有quantmod包和chartSeries()等函数吗?这是因为:第一,quantmod包的画图对我来说没有足够的灵活性,我不能很自如地控制每一个要素,添加我想要的东西;第二,quantmod包的分 ...
坛友互助群 |
扫码加入各岗位、行业、专业交流群 |
这是因为:第一,quantmod包的画图对我来说没有足够的灵活性,我不能很自如地控制每一个要素,添加我想要的东西;第二,quantmod包的分析是基于xts的时间序列对象,而在日常工作中,已经习惯了用tbl_df体系,也确实好用,而该体系的作图对应的就是ggplot2这一强大的工具。
好了,不说废话了,直接开始。
数据是2017年上证综指每日的开盘,最高,最低、收盘和成交量数据,在这个文件中,变量名"SHDX2017"。
开始作图:
- library(tidyverse)
- library(gridExtra)
- library(quantmod)# 要用到SMA函数
- # 为了解决日期作为横坐标会出现休市日的情况,需要以下的变量辅助
- row_len <- nrow(SHDX2017)
- breaks <- seq(1, row_len, 10)
- labels <- SHDX2017$date[breaks]
- # 作K线图
- p1 <- SHDX2017 %>%
- arrange(date) %>%
- mutate(ma5 = SMA(close, n = 5, align ="right"),
- ma10 = SMA(close, n = 10, align = "right"),
- date_axis = row_number()) %>%
- ggplot(aes(x = date_axis)) +
- geom_boxplot(aes(lower = pmin(close, open),
- middle = close,
- upper = pmax(close, open),
- ymin = low,
- ymax = high,
- group = date_axis,
- fill = open > close),
- stat = "identity",
- show.legend = FALSE) +
- geom_line(aes(y = ma5), color = "blue3") +
- geom_line(aes(y = ma10), color = "red") +
- scale_x_continuous(breaks = breaks,
- labels = NULL,
- expand = c(0, 0)) +
- theme(axis.ticks.x = element_blank(),
- axis.title = element_blank(),
- axis.text.y = element_text(margin = margin(l = 8)))
- # 作成交量图
- p2 <- SHDX2017 %>%
- arrange(date) %>%
- mutate(vol_ma5 = SMA(volume, n = 5, align ="right"),
- vol_ma10 = SMA(volume, n = 10, align = "right"),
- date_axis = row_number()) %>%
- ggplot(aes(x = date_axis, y = volume)) +
- geom_bar(stat = "identity",
- aes(fill = open > close),
- show.legend = FALSE) +
- geom_line(aes(y = vol_ma5), color = "blue3") +
- geom_line(aes(y = vol_ma10), color = "red") +
- scale_x_continuous(breaks = breaks,
- labels = format(labels, "%m-%d"),
- expand = c(0, 0)) +
- scale_y_continuous(expand = c(0, 0.5)) +
- theme(axis.title = element_blank())
- # 组合
- grid.arrange(p1, p2, nrow = 2, heights = 2:1)
作出的图像这样:
扫码或添加微信号:坛友素质互助
「经管之家」APP:经管人学习、答疑、交友,就上经管之家!
免流量费下载资料----在经管之家app可以下载论坛上的所有资源,并且不额外收取下载高峰期的论坛币。
涵盖所有经管领域的优秀内容----覆盖经济、管理、金融投资、计量统计、数据分析、国贸、财会等专业的学习宝库,各类资料应有尽有。
来自五湖四海的经管达人----已经有上千万的经管人来到这里,你可以找到任何学科方向、有共同话题的朋友。
经管之家(原人大经济论坛),跨越高校的围墙,带你走进经管知识的新世界。
扫描下方二维码下载并注册APP
免流量费下载资料----在经管之家app可以下载论坛上的所有资源,并且不额外收取下载高峰期的论坛币。
涵盖所有经管领域的优秀内容----覆盖经济、管理、金融投资、计量统计、数据分析、国贸、财会等专业的学习宝库,各类资料应有尽有。
来自五湖四海的经管达人----已经有上千万的经管人来到这里,你可以找到任何学科方向、有共同话题的朋友。
经管之家(原人大经济论坛),跨越高校的围墙,带你走进经管知识的新世界。
扫描下方二维码下载并注册APP
您可能感兴趣的文章
本站推荐的文章
人气文章
1.凡人大经济论坛-经管之家转载的文章,均出自其它媒体或其他官网介绍,目的在于传递更多的信息,并不代表本站赞同其观点和其真实性负责;
2.转载的文章仅代表原创作者观点,与本站无关。其原创性以及文中陈述文字和内容未经本站证实,本站对该文以及其中全部或者部分内容、文字的真实性、完整性、及时性,不作出任何保证或承若;
3.如本站转载稿涉及版权等问题,请作者及时联系本站,我们会及时处理。
2.转载的文章仅代表原创作者观点,与本站无关。其原创性以及文中陈述文字和内容未经本站证实,本站对该文以及其中全部或者部分内容、文字的真实性、完整性、及时性,不作出任何保证或承若;
3.如本站转载稿涉及版权等问题,请作者及时联系本站,我们会及时处理。