---
disqus: ahb0222
GA : G-CQ4L16KHK4
---
# R語言-股票套件quantmod & tidyquant
> [color=#40f1ef][name=LHB阿好伯, 2020/02/09][:earth_africa:](https://www.facebook.com/LHB0222/)
###### tags: `R` `股票` `可視化`
![](https://i.imgur.com/kPD8zdF.jpg)
[TOC]
最近找了一些資料學習R語言中的quantmod套件
目前tidyquant套件整合收集和分析財務數據的相關套件如:zoo、xts、quantmod、TTR和PerformanceAnalytics
:::success
xts/zoo: 處理時間序列之套件。
TTR: 計算金融資產技術指標之套件。
quantmod: 金融資產技術分析回測套件,可至Yahoo Finance或Google Finance下載歷史股價數據或其他金融相關數據。並且整合TTR套件,繪製出漂亮的技術分析圖析。
PerformanceAnalytics: 計算金融資產報酬績效指標之套件。
:::
用tidyverse允許每個套件之間的無縫使用
今天來介紹最基本的抓取台股資料與畫圖
[quantmod套件官網](http://www.quantmod.com/)
[quantmod套件文檔](http://www.quantmod.com/documentation/00Index.html)
[![](https://i.imgur.com/0Rwd3NU.png)tidyquant套件官網](https://business-science.github.io/tidyquant/index.html)
# 股票代號與名稱對應
目前quantmod套件中的名稱都是英文
所以我依照證交所提供的資料建立了對應表
用於後續畫圖可以顯示股票名稱
```r=
#R Code
install.packages('quantmod') #安裝套件
library(quantmod) # 載入套件
#股票代號對照表-2021/02/12更新
library(readr)
Snum_data <- read_csv("https://raw.githubusercontent.com/gtgrthrst/OpenData/main/%E8%82%A1%E7%A5%A8%E5%B0%8D%E7%85%A7.csv")
head(Snum_data)
```
:::success
number name Codename date type1 type2 type3
<dbl> <chr> <chr> <chr> <chr> <chr> <chr>
1 50 元大台灣50 TW0000050004 2003/6/30 上市 NA CEOGEU
2 51 元大中型100 TW0000051002 2006/8/31 上市 NA CEOGEU
3 52 富邦科技 TW0000052000 2006/9/12 上市 NA CEOGEU
4 53 元大電子 TW0000053008 2007/7/16 上市 NA CEOGEU
5 54 元大台商50 TW0000054006 2007/7/16 上市 NA CEOGEU
6 55 元大MSCI金融 TW0000055003 2007/7/16 上市 NA CEOGEU
:::
# 股票資料
抓取股票資料預設為yahoo的資料
台灣股票代碼格式為"XXXX.TW"
也可以添加`src ="google"`選擇Google財經的資料
也支援其他幾種資料
聖路易斯聯邦儲備銀行FRED®(11,000個經濟系列)
Oanda,貨幣網站(外彙和金屬)
MySQL數據庫(本地數據庫)
R二進制格式(.RData和.rda)
逗號分隔檔(.csv)
首先我們就先來看看台灣護國神山的股票
```r=
#R Code
Snum <- 2330 #設定台灣股票代碼
#取得股票資料
Sdata <- get(getSymbols(paste0(Snum,".TW"),src="yahoo",from="2020-01-01",to=Sys.Date())) #from為起始時間
Sname <- as.character(subset(Snum_data, number == Snum)[2])
chartSeries(Sdata, name = paste0(Snum,".TW"))
```
![](https://i.imgur.com/qmjQnqH.png)
## 均線(MovingAverage, MA)
全名為移動平均線
在看盤軟體中簡稱為MA
是股票技術分析中重要的參考指標之一
$均線 = {N天的收盤價加總}/{N}$
使用`runMean()`計算均線
在使用`addTA()`畫上均線即可
```r=
ma20<-runMean(Sdata[,4],n=20) #20天均線
ma60<-runMean(Sdata[,4],n=60) #60天均線
addTA(ma20,on=1,col="blue")
addTA(ma60,on=1,col="red")
```
大家若仔細看可以看到ma20與ma60的起點是不同的
主要原因就是平均資料是歷史資料
所以ma20在第20天過後才會有第一筆數值
ma60在60天過後才有
![](https://i.imgur.com/GGSkHXK.png)
## 布林通道(Bollinger Band)
又稱為布林軌道、布林帶、布林線,是由均線和標準差組成的指標
總共有三條線:中線,上線,下線
中線就是股價的移動平均線,一般是設定為20日的移動平均線(MA20)
上線也可稱為壓力線,通常是用中線加2個標準差
下線也稱為支撐線,通常是用中線減2個標準差(sd)
上下線構成的區域就是布林通道
在R中只需要使用`addBBands(n = 20, sd = 2)`就可以快速添加布林通道
```r=
addBBands(n = 20, sd = 2) #布林通道
```
![](https://i.imgur.com/8P8Bszk.png)
# Shiny 股票查詢網頁
最後在建立一個簡單的Shiny網站
```r=
#install.packages(c("quantmod","readr","shiny"))
library(shiny)
library(readr)
library(quantmod)
Snum_data <- read_csv("https://raw.githubusercontent.com/gtgrthrst/OpenData/main/%E8%82%A1%E7%A5%A8%E5%B0%8D%E7%85%A7.csv")
# Define UI for application that draws a histogram
ui <- fluidPage(
# Application title
titlePanel("股票查詢"),
# Sidebar with a slider input for number of bins
sidebarLayout(
sidebarPanel( textInput("Snum", "台股編號", value = 2330),
helpText("輸入台股代碼4-6碼即可查詢走勢"),
dateRangeInput("daterange1", "Date range:",
start = "2010-01-01",
min = "2010-01-01",
max = Sys.Date(),
end = Sys.Date()),
sliderInput("bins1",
"布林通道樣本數:",
min = 2,
max = 90,
value = 20),
),
# Show a plot of the generated distribution
mainPanel(
verbatimTextOutput("Sname"),
plotOutput("distPlot")
)
)
)
# Define server logic required to draw a histogram
server <- function(input, output) {
output$Sname <- renderText(as.character(subset(Snum_data, number == input$Snum)[2]))
output$distPlot <- renderPlot({
ma1<-runMean(Sdata[,4],n=input$bins1)
Sdata <- na.omit(get(getSymbols(paste0(input$Snum,".TW"),src="yahoo",
from=as.character(format(input$daterange1[1],"%Y-%m-%d")),
to=as.character(format(input$daterange1[2],"%Y-%m-%d"))))) #from改成自己要的起日
chartSeries(Sdata, name = paste0(input$Snum,".TW"))
# addTA(ma20,on=1,col="blue")
# addTA(ma60,on=1,col="red")
addBBands(n = input$bins1, sd = 2) #布林通道
})
}
# Run the application
shinyApp(ui = ui, server = server)
```
![](https://i.imgur.com/8TZO34g.png)
目前上傳至shinyapps.io出現一些問題
:::danger
Warning: 2330.TW download failed; trying again.
Warning in ensure_restore_map() :
closing unused connection 5 (https://query2.finance.yahoo.com/v7/finance/download/2330.TW?period1=1577836800&period2=1613088000&interval=1d&events=history&crumb=/BwmACBwTct)
Warning in ensure_restore_map() :
closing unused connection 4 (https://query1.finance.yahoo.com/v7/finance/download/2330.TW?period1=NA&period2=1613088000&interval=1d&events=history&crumb=/BwmACBwTct)
Warning in ensure_restore_map() :
closing unused connection 3 (https://query1.finance.yahoo.com/v7/finance/download/2330.TW?period1=NA&period2=1613088000&interval=1d&events=history&crumb=Vh7kl4iOG6G)
:::
等之後要是解決了在分享網址給大家
要是知道問題的歡迎指教
### 參考資料
>[證券編碼公告](https://www.twse.com.tw/zh/page/products/stock-code2.html)
>證交所
>[r語言自學日記-6-移動平均-ma-與常見股票圖表繪製](https://medium.com/r-%E8%AA%9E%E8%A8%80%E8%87%AA%E5%AD%B8%E7%B3%BB%E5%88%97/r%E8%AA%9E%E8%A8%80%E8%87%AA%E5%AD%B8%E6%97%A5%E8%A8%98-6-%E7%A7%BB%E5%8B%95%E5%B9%B3%E5%9D%87-ma-%E8%88%87%E5%B8%B8%E8%A6%8B%E8%82%A1%E7%A5%A8%E5%9C%96%E8%A1%A8%E7%B9%AA%E8%A3%BD-86bd12e884a6)
>[Tidyquant套件介紹](https://bap.cm.nsysu.edu.tw/rmarkdown/tidyquan.html)
>指導教授: 中山大學財務管理學系 王昭文 教授
>文章撰寫: 中山大學財務管理學系 蘇彥庭 研究助理
### [參考書籍-R語言:數學計算、統計模型與金融大數據分析(第二版)![](https://i.imgur.com/nYCxkqj.png)](https://www.books.com.tw/exep/assp.php/gtgrthrst4577/products/0010762541?sloc=main&utm_source=gtgrthrst4577&utm_medium=ap-books&utm_content=recommend&utm_campaign=ap-202102)
# [自動查詢上市上櫃股票資訊_R語言_tryCatch()](/fzspXQxhQWi8E-CTczmK1Q)
🌟全文可以至下方連結觀看或是補充
https://hackmd.io/@LHB-0222/quantmod
全文分享至
https://www.facebook.com/LHB0222/
https://www.instagram.com/ahb0222/
有疑問想討論的都歡迎於下方留言
喜歡的幫我分享給所有的朋友 \o/
有所錯誤歡迎指教
# [:page_with_curl: 全部文章列表](https://hackmd.io/@LHB-0222/AllWritings)
![](https://i.imgur.com/47HlvGH.png)