使用MPLFINANCE 打造一個互動的顯示股票線圖工具(3)[QuantTradingwithPython_3]

閱讀時間約 18 分鐘
  • 文內如有投資理財相關經驗、知識、資訊等內容,皆為創作者個人分享行為。
  • 有價證券、指數與衍生性商品之數據資料,僅供輔助說明之用,不代表創作者投資決策之推介及建議。
  • 閱讀同時,請審慎思考自身條件及自我決策,並應有為決策負責之事前認知。
  • 方格子希望您能從這些分享內容汲取投資養份,養成獨立思考的能力、判斷、行動,成就最適合您的投資理財模式。


raw-image


首先。先跟大家說一個令人振奮的消息。在這一篇文章當中。我們終於即將完成K線圖形顯示程式。這個未來會常常使用的小工具完工啦!就說興不興奮,高不高興。這段時間總算沒有白費;我們真的給鼓搗出了一些東西,這下子應該不只可以面對家鄉的父老了;都有一種榮歸故里的感覺。

還是先拿出來讓大家看看完工的樣子。還有我們日以繼夜,精工細琢出來的程式碼。忍不住就直接先來一個三連拍。



raw-image



raw-image


raw-image





看到了吧?直接上豪華下拉式選單Dropdown。外加航空級線傳飛控絲滑數位顯示天數滑動條。這一套下來,就算是目前最招搖的F1賽車;不只看不到咱們的尾燈,連想品嚐廢氣棄的機會直接都不給。接下來就給大家直接展示,我們這段不到10萬行的精悍程式碼。




import yfinance as yf

import mplfinance as mpf

import ipywidgets as widgets

from IPython.display import display, clear_output




data = None




def download_data(code):

    global data

    data = yf.download(code, start='2023-01-01', end='2023-06-11')




#建立股票代碼下拉式選單widget.

code_dropdown = widgets.Dropdown(

    options=['AAPL', 'NVDA', 'TSLA',’2330.TW’],

    value='AAPL',

    description='Stock Code:',

    disabled=False,

)




# 下載初始資料(全域變數)

download_data(code_dropdown.value)




# 建立顯示天數的滑動條 IntSlider widget




days_slider = widgets.IntSlider(

    value=5,

    min=5,

    max=len(data),

    step=1,

    description='Days:',

    disabled=False,

    continuous_update=False,

    orientation='horizontal',

    readout=True,

    readout_format='d'

)




# 建立執行的按鍵 Button widget

submit_button = widgets.Button(

    description='Plot Chart',

    disabled=False,

    button_style='', # 'success', 'info', 'warning', 'danger' or ''

    tooltip='Click to plot chart',

    icon='check' # (FontAwesome names without the `fa-` prefix)

)




def on_submit_button_clicked(b):

    # Get the input values

    code = code_dropdown.value

    days = days_slider.value




    # Set the candlestick colors and style

    my_color = mpf.make_marketcolors(up='r', down='g', edge='inherit', wick='inherit', volume='inherit')

    my_style = mpf.make_mpf_style(marketcolors=my_color, figcolor='(0.82, 0.83, 0.85)', gridcolor='(0.82, 0.83, 0.85)')




    # Clear the previous chart

    clear_output(wait=True)

    

    # Plot the candlestick chart

    mpf.plot(data.tail(days), type='candle', volume=True, style=my_style, title=str(code), figsize=(8, 5))

    

    # Redisplay the input widgets and button

    display(code_dropdown, days_slider, submit_button)




submit_button.on_click(on_submit_button_clicked)




# 檢查輸入代碼是否更新

Define a function to handle stock code changes

def on_code_dropdown_change(change):

    if change['type'] == 'change' and change['name'] == 'value':

        download_data(change['new'])




# Attach the change event handler to the dropdown

code_dropdown.observe(on_code_dropdown_change)













在解釋全部的代碼之前,還是要先來介紹今天加入的兩個小夥伴。首先加入的就是下拉式選單功能的小部件Dropdown widget。在這一次,將原來文字輸入的小部件Text widget,升級成了這種下拉式的選單,方便可以先把聚焦要顯示的股票代碼,一次全部都放進去;比如我們未來篩選出來的股票池。如此;只要在下拉式選單中直接點選,就再也不需要借用鍵盤來輸入了。這個功能我是很有私心的;回臺灣之後,面對的這個花花綠綠的鍵盤,一下子中英文切換的;然後冷不防的又來一個全形半形,已經整個人都快扭曲了。怎麼也不會想到,40多年的友誼小船,才經過1000多個日子;竟然說翻就翻。所以,看到這個下拉式選單,可真是興奮他媽給興奮開門;興奮到家了。以下是這個下拉式選單小部件的示範程式碼。




import ipywidgets as widgets

widgets.Dropdown(

    options=['1', '2', '3'],

    value='2',

    description='Number:',

    disabled=False,

)

這裡比較值得一提的。就是options了。後面的數列['1', '2', '3']。在選單中的所有項目,都是放在這個數列當中。然後下面那一行的value,便是當選單工作的時候,顯示出來的內定值。當然這個必須要是options當中的其中一員,不要問我為什麼?

接著我們來認識一下滑動條這個小部件。直接上示範程式碼。




import ipywidgets as widgets




widgets.IntSlider(

    value=7,

    min=0,

    max=10,

    step=1,

    description='Test:',

    disabled=False,

    continuous_update=False,

    orientation='horizontal',

    readout=True,

    readout_format='d'

)

首先我們看到這個小部件;它的全名叫Intslider。顧名思義它是處理屬於整數intger部分的數值。在我們的小部件家族裡,也有可以處理浮點小數的滑動條FloatSlider。 orientation='horizontal' 沒錯!不是眼花,你沒看錯這個字是叫做水平horizontal。所以它一定還有一個失散兄弟叫做垂直vertical;就說你服不服。兩個新入伙的夥伴介紹完了,其他的時間就開始來整我們的程式碼,因為今天真的有蠻多東西要說的。




def download_data(code):

    global data

    data = yf.download(code, start='2023-01-01', end='2023-06-11')


raw-image






程式一開頭這三行,應該就會把不少人整頭大了。不要急,聽我慢慢道來。這3行是一夥的,是我們Python裡面的副程式Function。副程式的名稱就叫做”Down load data”;顧名思義就是要下載資料。之後帶入的code,就是股票代碼。這行當中把data這個變數。宣告為global;在Python當中,就代表了這個data被宣告成了全域型的變數。至於為什麼要在這個地方把它宣告成全域型的變數呢?因為我在寫這段程式碼的當中,發現當使用滑動條改變了顯示天數。在原先的程式當中它都會再一次的去向Yahoo資料庫提出下載的需求;感覺上會拖慢了我們執行程式的效率。所以最終程式定案的時候,當下拉選單當中股票代碼沒有被更動或更新,我們便不需要再向資料庫提出下載的需求。而這個全域變數的宣告,就能解決我們這個問題。




#建立股票代碼下拉式選單widget.

code_dropdown = widgets.Dropdown(

    options=['AAPL', 'NVDA', 'TSLA',’2330.TW’],

    value='AAPL',

    description='Stock Code:',

    disabled=False,

)




# 下載初始資料(全域變數)

download_data(code_dropdown.value)




接下來的這部分程式碼,大夥應該知道;就是設定下拉式選單。然後緊接著程式的最後就呼叫了剛才的那個設定全域變數的資料下載副程式。首先解釋一下,以免大家困惑了。其實在模組化的程式當中,並不是依程式碼的排列次序,來想像它的執行順序。就比如這段下載資料的程式碼,它是一個副程式;所以他在全部的程式當中,可能在任何一個位置被呼叫。所以它上面的小部件宣告,也不是宣告完成後就開始去執行的。它是被display指定名稱呼叫時才會執行。所以在我們的程式碼當中。最後這一行 display(code_dropdown, days_slider, submit_button) 我們也可以把它想像成;這裡是所有程式碼執行的開端。因為把這些小部件顯示之後,它才會開始工作。然後我們才可以從這些部件當中接收到接下來所需要的工作變數。




# 建立顯示天數的滑動條 IntSlider widget




days_slider = widgets.IntSlider(

    value=5,

    min=5,

    max=len(data),

    step=1,

    description='Days:',

    disabled=False,

    continuous_update=False,

    orientation='horizontal',

    readout=True,

    readout_format='d'

這段應該說大家都知道。是在初始之後要顯示天數的滑動條。初值顯示為5天,最小值也是5天。它的增加單位step為一天。要注意的是。最大值的設定;在這一項中,我們並不是直接輸入一個固定的數字;而是使用了max=len(data)。這裡所帶入的是data這個資料的長度。也就是我們限制了顯示天數的最大值,為資料的總天數。如此來保證它不會出軌。好一個感情的守護天使。

def on_submit_button_clicked(b):

    # Get the input values

    code = code_dropdown.value

    days = days_slider.value

然後接下來這裡又有一段副程式,是在我們點了按鍵之後所呼叫的。這裡可以看到。從下拉式選單當中,取得我們選擇的股票代碼。以及在滑動條當中得到所想要的顯示天數。然後接下來就是再熟悉不過的一些顯示圖形的程式碼。

# Plot the candlestick chart

    mpf.plot(data.tail(days), type='candle', volume=True, style=my_style, title=str(code), figsize=(8, 5))

    

    # Redisplay the input widgets and button

    display(code_dropdown, days_slider, submit_button)




submit_button.on_click(on_submit_button_clicked)




接著我們此行完所有的K線圖形顯示之後。我們又在一次呼叫了顯示小部件的display。這個原因是因為原先程式碼如果沒有加上這一段新的程式敘述。則會在第一次顯示圖形之後。這些小部件便都會消失了。所以必須要再重新把它們喚醒。我們不必為它特別再去設計一些迴圈,因為下回程式在跑到顯示圖形這一部分的時候,便自動順道又會跑到重新喚醒這部分功能。所以這樣就會保證我們的這些小部件,一直都會顯示出來,而不會平白無故地消失。

這裡容我插一下話;我們這段程式說長也不長。但是其實在寫作的過程裡面,還是有幾個問題需要花一些時間去克服它的。最原先當每次選擇了不同的股票代碼,或者改變了顯示天數的時候,程式碼都會重複的去資料庫下載資料。以及新生成一個圖形的物件,來顯示所要的結果。所以一些時間下來,很快的就會發現;我們已經完成了一幅近代的清明上河圖。所以做了一些事情,包含了就是一次下載所有的資料,並宣告為全域變數;來讓它一直在同一個畫面里面顯示我們所要的結果。然後就是發現剛才所講的;當第一步克服之後,便發現了這些小部件,在第一次工作執行完以後就壽終正寢了。解決的方法就是剛才所提的重新再去呼叫,讓它顯示出來。以下這段程式碼,便是在檢查是否將顯示的股票代碼改變?如果股票代碼被改變;即便需要重新再到資料庫去下載全部的歷史資料。

# 檢查輸入代碼是否更新

Define a function to handle stock code changes

def on_code_dropdown_change(change):

    if change['type'] == 'change' and change['name'] == 'value':

        download_data(change['new'])




# Attach the change event handler to the dropdown

code_dropdown.observe(on_code_dropdown_change)


最後還有一點值得一提的。看看。以下的這段程式碼。

# Set the candlestick colors and style

    my_color = mpf.make_marketcolors(up='r', down='g', edge='inherit', wick='inherit', volume='inherit')

    my_style = mpf.make_mpf_style(marketcolors=my_color, figcolor='(0.82, 0.83, 0.85)', gridcolor='(0.82, 0.83, 0.85)')




    # Clear the previous chart

    clear_output(wait=True)

    

    # Plot the candlestick chart

    mpf.plot(data.tail(days), type='candle', volume=True, style=my_style, title=str(code), figsize=(8, 5))

特別注意。在我們顯示K線圖形的指令之前。有一個很特殊的指令;它也是這次排除的一個小問題。就是在大量的顯示圖形之後,電腦的記憶體將很容易遇到滿載。問題在於,之前顯示的這些圖形佔用的記憶體並沒有被順利的卸載乾淨。所以必須加入這條指令,來清除之前顯示圖形所佔用的記憶體。特別要注意的是;這行指令請務必加在顯示圖形之前。至於為什麼啊?你就當做服藥有分為飯前跟飯後就好了。好吧!不亂扯了。很高興,大家終於把這個圖形顯示的工具完成了。希望大伙看得愉快,也用的愉快。下一次,我們將直接進入更深入的怎麼建立股票池的問題?所以今天就先談到這裡了。祝各位早安午安晚安。

raw-image



avatar-img
7會員
19內容數
一個專為金融專業設計的專題。介紹量化交易的基本概念和使用Python進行量化交易策略開發的方法。專題涵蓋金融市場運作、技術分析,實例和代碼提供,幫助理解和應用不同的交易策略和指標。此外,介紹了回測工具的使用和風險管理技巧。本專題為對量化交易有興趣的讀者提供了全面的學習指南。
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
Parkson Dow的沙龍 的其他內容
嗨又見面了!接下來就繼續下去我們的程式互動之旅之旅.相信應該沒有人會以為我們用一個簡單的input,就交代了想要的互動功能.在這一篇當中將帶領大家,真正的體會,炫酷又好玩的Jupyter notebook互動功能.將程式介面提升到一個讓自己愛不釋手的檔次。
 大家好。很高興在這個新的部落格上面。有機會能再跟大家一起討論交易的兩三事。未來我們將在這個新的地方上面;與大家一步一步地,建立起屬於我們自己個性化的量化交易平臺;敬請期待。
嗨又見面了!接下來就繼續下去我們的程式互動之旅之旅.相信應該沒有人會以為我們用一個簡單的input,就交代了想要的互動功能.在這一篇當中將帶領大家,真正的體會,炫酷又好玩的Jupyter notebook互動功能.將程式介面提升到一個讓自己愛不釋手的檔次。
 大家好。很高興在這個新的部落格上面。有機會能再跟大家一起討論交易的兩三事。未來我們將在這個新的地方上面;與大家一步一步地,建立起屬於我們自己個性化的量化交易平臺;敬請期待。
你可能也想看
Google News 追蹤
Thumbnail
這篇是給初學技術分析者的建議,覺得去蕪存菁,最簡潔有效的東西。 1.認識什麼是K線,開高低收,成交量。 2.知道均線與均量的數學意義。 3.學習簡單的走勢型態,比如W底M頭,切線,跳空缺口。 以上3點就足夠了,不管基於什麼說法想法理由,都不要花時間去學任何其他指標。
Thumbnail
雖然已經使用技術分析那麼多年,但是偶而還是不免會懷疑打了點小問號,因為台股漲到這邊真的覺得已經超乎預期跟想像,技術面漲滿足估算真的會發生嗎...
Thumbnail
#櫃檯指數 目前漲幅滿足也到了 所以可以看到近期很多滿足到的產業題材都會有人獲利資金出場 有的積極型就再繼續短線轉換到下一個題材,有的就保守等待過程機會 在這邊才開始想拼命的投資人,風險就比已經有滿足到的人還高 就跟銅期貨滿足一樣,後面才想拼命的就是風險高峰期,運氣差沒算準最後
詳細資料盤後再弄~ 今天我的滿分股也很不錯! 朋程~其餘的有些需要等待有些已經表態~ 好好善用這張表會給大家很大的幫助!大家可以驗證看看~ 大家都會用吧!?
Thumbnail
我們一直追蹤的終於有挑戰突破252 所以今天市場的胃口才被打開,多數中小型個股開始有表態 預計這就是520延續到6/11蘋果發表會的節奏 資金一樣會輪流所以不要每天追高潮 就像之前電子股難熬 營建股 金融股 資產股高昂 而現在追在這三個題材高潮點的投資人又開始想要換 永遠都是"靠運氣在
Thumbnail
學習K線圖的好處是能夠在這項技能當中研判各國股市、匯率或個股的趨勢脈動,因K棒的形成是真金白銀打出來的型態,就是最真實的市場的反映,若將K棒及成交量結合,就能掌握大部分市場的走向,未來您可以做波段或是當沖交易都適用,就不需要再聽任何消息能夠自己做判斷。
Thumbnail
本文章介紹如何使用XQ的數據報價源,利用Excel設計動態的技術K線圖。完成學系後你將學會Excel個股動態技術K線圖,Excel期貨動態技術K線圖,Excel加權動態技術K線圖,Excel成交量製作,與Excel均線的繪製。
Thumbnail
這篇是給初學技術分析者的建議,覺得去蕪存菁,最簡潔有效的東西。 1.認識什麼是K線,開高低收,成交量。 2.知道均線與均量的數學意義。 3.學習簡單的走勢型態,比如W底M頭,切線,跳空缺口。 以上3點就足夠了,不管基於什麼說法想法理由,都不要花時間去學任何其他指標。
Thumbnail
雖然已經使用技術分析那麼多年,但是偶而還是不免會懷疑打了點小問號,因為台股漲到這邊真的覺得已經超乎預期跟想像,技術面漲滿足估算真的會發生嗎...
Thumbnail
#櫃檯指數 目前漲幅滿足也到了 所以可以看到近期很多滿足到的產業題材都會有人獲利資金出場 有的積極型就再繼續短線轉換到下一個題材,有的就保守等待過程機會 在這邊才開始想拼命的投資人,風險就比已經有滿足到的人還高 就跟銅期貨滿足一樣,後面才想拼命的就是風險高峰期,運氣差沒算準最後
詳細資料盤後再弄~ 今天我的滿分股也很不錯! 朋程~其餘的有些需要等待有些已經表態~ 好好善用這張表會給大家很大的幫助!大家可以驗證看看~ 大家都會用吧!?
Thumbnail
我們一直追蹤的終於有挑戰突破252 所以今天市場的胃口才被打開,多數中小型個股開始有表態 預計這就是520延續到6/11蘋果發表會的節奏 資金一樣會輪流所以不要每天追高潮 就像之前電子股難熬 營建股 金融股 資產股高昂 而現在追在這三個題材高潮點的投資人又開始想要換 永遠都是"靠運氣在
Thumbnail
學習K線圖的好處是能夠在這項技能當中研判各國股市、匯率或個股的趨勢脈動,因K棒的形成是真金白銀打出來的型態,就是最真實的市場的反映,若將K棒及成交量結合,就能掌握大部分市場的走向,未來您可以做波段或是當沖交易都適用,就不需要再聽任何消息能夠自己做判斷。
Thumbnail
本文章介紹如何使用XQ的數據報價源,利用Excel設計動態的技術K線圖。完成學系後你將學會Excel個股動態技術K線圖,Excel期貨動態技術K線圖,Excel加權動態技術K線圖,Excel成交量製作,與Excel均線的繪製。