# 台股個股線圖繪製─Python筆記(2)
###### tags: `Python` `Coding`
![](https://i.imgur.com/y9uS8fm.png)
## 台股個股線圖
這篇的內容很單純,就是要畫出這個圖啦!!!
在[前一篇文章](https://finrodchen.net/2020/05/26/%e5%8f%b0%e8%82%a1%e8%b3%87%e6%96%99%e7%88%ac%e8%9f%b2-python%e5%ad%b8%e7%bf%92%e7%ad%86%e8%a8%98/)中,我們已經能使用`twstock`模組抓取特定個股的交易歷史,並且使用`pandas`模組把清單(list)加上表頭並轉換成Data Frame資料表,接著再將資料表的內容儲存為`.csv`檔案。接下來只要我們定期更新個股股價,便能開始研究價格走勢了。
在這張圖中我們可以看到幾個主要項目:
### K線
![](https://i.imgur.com/zA6NLux.png=====================================================================[ㄤ
K線又稱作蠟燭線,一根蠟燭表示一天自開盤到收盤的價格表現,其中紅色代表上漲,綠色代表下跌,而中間的蠟燭上下限標記開盤及收盤價格,K線的上下橫線則為當日最高與最低價格。
### 均線
均線紀錄了一段特定時間中股票持有成本的平均值,英文原名是Moving Average(MA),舉例來說,下表是某檔股票5日的收盤價格,將5日的價格加總除以5即為5日均價,以每一天為中心計算前後兩日加總的均價,就能連成一條5日價格均線了。
時間|D-2|D-1|D0|D+1|D+2|5日均價
---|---|---|---|---|---|---
價格|52.5|53.0|59.5|55.2|49.5|53.94
而隨著加總平均計算的天數不同,均線代表的意涵也不同,以下是常見的均線技術分析:
均線種類|說明|分析意義
---|---|---
5日均線|周線,極短線操作指標|飆股跌破周線可能是出場時機
10日均線|雙周線,短線操作指標|強勢股跌破雙周線可能會進入短期整理
20日均線|月線,多頭操作指標|跌破月線可能會進入短期空頭修正格局
60日均線|季線,中期操作指標|跌破季線可能會進入中期空頭修正格局
240日均線|年線,長期操作指標|跌破季線可能會進入長期空頭修正格局
除了這5種算法以外,還有許多不同日數加總的判斷方式(例如6日線、22日線等),但對趨勢判斷的影響不會很大。程式中我設定顯示5、10及20日均線用於分析。
### 交易量
圖片下方的副圖表為每日的交易量,長條圖顏色對應當日的漲跌顯示。
## Python程式中使用的模組
在這個程式中會用到以下幾個模組:
- pandas:讀取`.csv`檔案,將股價資料轉為Data Frame資料表格式
- matplotlib:Python科學繪圖的主要模組,功能超級強大
- mplfinance:matplotlib旗下專門用於金融分析的繪圖模組,詳細的使用方式可參照[開發者GitHub](https://github.com/matplotlib/mplfinance)
## 資料前處理
首先引入需要的模組
```python=
import pandas as pd
import matplotlib
import mplfinance as mpf
```
設定我們要讀取的股票代號,再由pandas的`pd.read_csv()`功能讀取`.csv`檔案
```python=
target_stock = '0050'
df = pd.read_csv(f'./data/{target_stock}.csv', parse_dates=True, index_col=1)
```
接著要對資料表中的Turnover表頭做一點修改,由於mplfinance模組中對於交易量的辨認是Volume這個字,所以我們使用pandas的`df.rename()`功能調整表頭。
```python=
df.rename(columns={'Turnover':'Volume'}, inplace = True)
```
這樣一來資料就準備好了,可以開始畫圖了!
## 開始畫圖吧!
由於mplfinance內建的漲/跌標記顏色是美國的版本(綠漲紅跌),所以我們要先使用mplfinance中自訂圖表外觀功能`mpf.make_marketcolors()`將漲/跌顏色改為台灣版本(紅漲綠跌),接著再將這個設定以`mpf.make_mpf_style()`功能保存為自訂的外觀。
```python=
mc = mpf.make_marketcolors(up='r', down='g', inherit=True)
s = mpf.make_mpf_style(base_mpf_style='yahoo', marketcolors=mc)
```
其他圖表的細節設定(類型、均線、顯示交易量、圖表標題、套用外觀等...)我們則建立一個可變參數將它們都放在裡面,這個做法當你有多張圖表要共用設定參數時會非常方便喔。
```python=
kwargs = dict(type='candle', mav=(5,20,60), volume=True, figratio=(10,8), figscale=0.75, title=target_stock, style=s)
```
最後只要很簡單的使用`mpf.plot()`就完成啦!
```python=
mpf.plot(df, **kwargs)
```
## 台股走勢圖繪圖成果
![](https://i.imgur.com/7ZSnlks.png)
啟動程式後,會開啟一個視窗,除了有我們畫出的股價走勢圖外,matplotlib模組提供了圖表放大縮小與儲存圖檔的功能,也可以再調整圖表顯示的細節,功能真的超級強大。
## 完整程式碼
```python=
import pandas as pd
import matplotlib
import mplfinance as mpf
# 導入pandas、matplotlib、mplfinance模組,將mplfinance模組縮寫為mpf
# 這邊要導入matplotlib的原因是因為mplfinance繪圖時需要調用mptplotlib模組
target_stock = '0050' #設定要繪製走勢圖的股票
df = pd.read_csv(f'./data/{target_stock}.csv', parse_dates=True, index_col=1) #讀取目標股票csv檔的位置
df.rename(columns={'Turnover':'Volume'}, inplace = True)
#這裡針對資料表做一下修正,因為交易量(Turnover)在mplfinance中須被改為Volume才能被認出來
mc = mpf.make_marketcolors(up='r',down='g',inherit=True)
s = mpf.make_mpf_style(base_mpf_style='yahoo',marketcolors=mc)
#針對線圖的外觀微調,將上漲設定為紅色,下跌設定為綠色,符合台股表示習慣
#接著把自訂的marketcolors放到自訂的style中,而這個改動是基於預設的yahoo外觀
kwargs = dict(type='candle', mav=(5,20,60), volume=True, figratio=(10,8), figscale=0.75, title=target_stock, style=s)
#設定可變參數kwargs,並在變數中填上繪圖時會用到的設定值
mpf.plot(df, **kwargs)
#選擇df資料表為資料來源,帶入kwargs參數,畫出目標股票的走勢圖
```