一分鐘搞定台股數據:證交所OpenAPI無需爬蟲輕鬆獲取

閱讀時間約 9 分鐘

對於剛接觸Python程式的使用者來說,要一口氣學會爬蟲可能相對困難,但若想即時且輕鬆獲得台股相關數據,你可以利用證交所所提供的API進行數據蒐集。只需要簡單幾行程式碼,就能輕鬆抓到台股上千支股票的每日資訊,是不是棒呆了!!

了解證交所API

我們示範請求上市個股的每日成交資訊的API,其他API的請求方式也是大同小異,學習完後可以自行練習抓取其他API看看。

從下圖可以發現幾個重點:

  1. 該API是以GET的方式進行請求,這意味著我們可以通過HTTP請求直接從服務器獲取數據,而不需要進行複雜的資料發送或處理。
  2. 該API的功能是取得台股上市個股的每日成交資訊,也就是說,我們可以通過這個API輕鬆獲得每一支股票在每日的交易數據,包括成交量、成交價等詳細資訊。

這時候可能有人會問,怎麼都只有介紹,那最重要的API呼叫網址在哪呢?別擔心,只需要點擊右側的「Try it out」按鈕後按「Execute」,即可顯示出API的完整呼叫網址囉!!

證交所API

證交所API

按「Execute」後,可以發現幾個重點(下圖):

  1. 最上方的網址就是剛剛按下Execute後顯示的,該網址正是我們要請求API的網址
  2. Dowload file可以直接下載呼叫完API所獲得的資料
  3. Response headers是HTTP回應標頭,這些標頭共同作用,確保客戶端能正確處理和顯示伺服器回應的數據。讓我們逐一解釋它們的意義:
    • connection: keep-alive : 這表示伺服器要求保持連接打開,以便在未來的請求中重用。
    • content-disposition: attachment;filename=STOCK_DAY_ALL.json: 這表示回應內容應被視為附件,並建議瀏覽器將其保存為名為STOCK_DAY_ALL.json的文件。
    • content-encoding: gzip: 這表示回應內容使用gzip壓縮進行編碼,客戶端需要解壓縮才能讀取內容。
    • content-type: application/json: 這表示回應內容的MIME類型是JSON格式。
    • date: Fri, 28 Jun 2024 14:14:23 GMT: 這是伺服器生成此回應的時間和日期。
    • etag: W/"667dd2fc-412bc": 這是一個唯一標識符,用於資源的版本控制,幫助瀏覽器判斷資源是否已更改。
    • last-modified: Thu, 27 Jun 2024 21:00:44 GMT: 這表示資源最後一次修改的日期和時間。
    • server: nginx: 這表示伺服器軟體是Nginx。
    • transfer-encoding: chunked: 這表示回應內容以分塊傳輸編碼方式發送,適用於動態生成的內容。
  4. Response 200: 表示請求API成功時會回覆200。
  5. Example Value: 表示請求API成功後會回傳哪些數據,以及每個數據種類的類別。
  6. Model: 如果對於回傳數據的種類英文名稱不懂究竟是哪些數據,可以點擊Model,便會說明每個種類的中文名稱是什麼。
證交所API

證交所API

請求證交所API

請求API很簡單,我們只要利用「requests」便可輕鬆請求,而requests有兩種請求API的方式,一個是GET,一個是POST,而我們在上面介紹到該API是GET的方式,因此我們程式碼便是利用requests.get的方式進行請求,可以看到出來的結果為「Response [200]」,表示請求成功。

  • requests: 是Python中一個非常流行的HTTP庫,用來發送HTTP請求。
# 引入requests庫
import requests
# 定義API的URL
url = 'https://openapi.twse.com.tw/v1/exchangeReport/STOCK_DAY_ALL'
# 發送GET請求
res = requests.get(url)
res
response200

response200

數據視覺化

請求完API後就是要呈現數據了。從上面的介紹可以知道我們請求的數據格式是「json」格式,因此我們利用json.loads的方式解析請求回來的數據。

import json

jsondata = json.loads(res.text)
jsondata
json

json

json格式對於使用者來說要進行數據處理跟分析會是比較難使用的方式,因此我們可以透過pandas套件進行數據呈現,以利後續一些數據處理。

  • pandas: 是Python中用於數據處理和分析的強大工具
# 引入pandas庫
import pandas as pd
# 將JSON數據轉換為DataFrame
df = pd.DataFrame(jsondata)
# 將"Code"列設置為索引
df.set_index("Code", inplace=True)
# 將空字符串替換為'0'
df.replace('', '0', inplace=True)
# 將除了"Name"列以外的所有列轉換為浮點數
df[df.columns.difference(['Name'])] = df[df.columns.difference(['Name'])].astype(float)
# 顯示DataFrame
df
DataFrame

DataFrame

最後我們利用請求到的數據進行簡單的兩個圖表呈現:

  1. 畫出收盤價前10大的股票
  2. 畫出成交量前10大的股票

※ 為解決中文字體在畫圖中顯示異常,可以添加以下程式碼

import matplotlib.pyplot as plt
plt.rcParams['font.sans-serif'] = ['Microsoft JhengHei'] # 修改中文字體
plt.rcParams['axes.unicode_minus'] = False # 顯示負號


從下圖可以看出,目前台股上市公司的「股神」仍然是我們的大立光。大立光長期以來在光學鏡頭和光電元件領域保持著領先地位,依靠其卓越的技術和穩定的市場需求,保持著高股價。緊隨其後的是緯穎、世芯-KY等公司。這些公司的成功並非偶然,而是與當前的市場趨勢密切相關。正如我們從前十大股價公司中所見,目前市場上的投資熱點集中在AI熱潮以及相關的半導體、伺服器和其他硬體設備上。這些技術需求的增長不僅提升了相關公司的業績,還讓它們成為投資者眼中的獵物。

# 按收盤價排序並選取前10大收盤價的股票
top10_closing = df.nlargest(10, 'ClosingPrice')

# 視覺化
plt.figure(figsize=(15, 6))
bars = plt.bar(top10_closing['Name'], top10_closing['ClosingPrice'], color='skyblue')
plt.title('Top 10 Closing Prices',fontsize=20)
plt.xlabel('Stock Name',fontsize=20)
plt.ylabel('Closing Price',fontsize=20)
plt.xticks(fontsize=20)
# 在每個條形圖上顯示對應的股價
for bar in bars:
yval = bar.get_height()
plt.text(bar.get_x() + bar.get_width()/2, yval, round(yval, 2), ha='center', va='bottom', fontsize=12)

plt.show()
Price_top_10

Price_top_10

如果我們從成交量的角度進行分析,可以發現前十大交易量的股票與前十大股價的公司有著顯著的不同。其中,近期最受歡迎的股票正是新發行的元大台灣價值高息ETF (00940)。這支ETF以其低成本和高股息月月配的特性,吸引了大量投資者的目光,尤其是那些重視穩定回報和被動收入的投資者。這也正好符合我身邊朋友們最近熱烈討論要買進的話題。 其次,引起廣泛關注的還有元大台灣50反1 (台股反向ETF),這類反向ETF的交易量大增,或許反映了市場投資者對於當前股價屢創新高的擔憂。由於股市漲幅持續,投資者擔心隱含的崩跌風險,因此購買反向ETF來進行風險對沖,保護自己的投資組合免受潛在的市場下跌影響。 這些現象表明,在目前的市況下,投資者既在尋求穩健的被動收入,同時也在思考如何應對股市高漲帶來的不確定性。元大台灣價值高息 (00940) 這類高配息的ETF提供了持股收益的穩定性,而元大台灣50反1則為那些擔心市場回調的投資者提供了一個對沖的工具,兩者各攬其道,共同成為當前市場上的交易熱點。

Trade_top_10

Trade_top_10


avatar-img
173會員
59內容數
我出生於財務金融與資訊背景,滿20歲便開始踏入股市。從當初對股市一無所知的菜鳥,到現在成為一名專注於AI股市研究的分析師,這是我的成長歷程。   我崇尚彼得·林區所強調的理念,認為在生活和工作中觀察,從周遭環境中挑選出適合投資的股票,並搭配近期快速崛起的程式交易、大數據分析等AI技術,立志打造輕鬆又便利的投資之路。
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
對於剛開始接觸Python的新手來說,無疑會在眾多執行環境中迷茫,不知道應該選擇哪一個比較好? 在這個情況下,我會推薦一個好的起點– Anaconda。現在,讓我們花費一分鐘的時間,我將引導你成功安裝Anaconda,並且正式開啟你在資料科學領域的旅程!
理解一個全新的操作環境有時候可能是一個挑戰,尤其對於那些剛開始接觸VS Code的開發者來說,即便具備一定的英文閱讀能力,可能也會對這個陌生的操作環境感到徬徨和不安。不過,沒有必要擔心,我們接下來就來一起用短短的一分鐘時間,將VS Code轉換成最熟悉的中文環境吧! 安裝繁體中文語言包 由於VS
對於剛開始接觸Python的新手來說,無疑會在眾多執行環境中迷茫,不知道應該選擇哪一個比較好? 在這個情況下,我會推薦一個好的起點– Anaconda。現在,讓我們花費一分鐘的時間,我將引導你成功安裝Anaconda,並且正式開啟你在資料科學領域的旅程!
理解一個全新的操作環境有時候可能是一個挑戰,尤其對於那些剛開始接觸VS Code的開發者來說,即便具備一定的英文閱讀能力,可能也會對這個陌生的操作環境感到徬徨和不安。不過,沒有必要擔心,我們接下來就來一起用短短的一分鐘時間,將VS Code轉換成最熟悉的中文環境吧! 安裝繁體中文語言包 由於VS
你可能也想看
Google News 追蹤
Thumbnail
徵的就是你 🫵 超ㄅㄧㄤˋ 獎品搭配超瞎趴的四大主題,等你踹共啦!還有機會獲得經典的「偉士牌樂高」喔!馬上來參加本次的活動吧!
Thumbnail
隨著理財資訊的普及,越來越多台灣人不再將資產侷限於台股,而是將視野拓展到國際市場。特別是美國市場,其豐富的理財選擇,讓不少人開始思考將資金配置於海外市場的可能性。 然而,要參與美國市場並不只是盲目跟隨標的這麼簡單,而是需要策略和方式,尤其對新手而言,除了選股以外還會遇到語言、開戶流程、Ap
在此篇中,我們來拿實務的例子作實戰練習,我們會討論如何在Google Colab的環境下,撈取所有台美股的股票代碼,並獲取相關細節,最後將獲取的資訊存取於SQLite資料庫中。
Thumbnail
可能包含敏感內容
各位先進讀者好!台指選擇權課程將區分為三階段,看看哪一種方案最適合你學選擇權的投資。 #選擇權交易將會是未來台股投資最耀眼的商品 因為選擇權不需要在股海裡找出股王,也不需要99種技術分析,真正好的技術分析是自己練就出來的。本專欄已經有越來越多讀者在關注與私下聯繫各自的問題跟需求。如果有問
Thumbnail
透過分析臺灣好行的公開資料,分享如何用Python繪製折線圖
Thumbnail
我們先快速回顧今天的行情,籌碼分析要等到下午四點公佈數據之後才能在晚上寫一篇新的文章出來給讀者參考。這篇檢討務必看,我有保存珍貴資料 今日的行情從開盤到收盤,從最高點到最低點,一共造成800點的震盪行情。主力再度同時誘多與誘空,讓他的選擇權暴漲,同時做賣方吸取選擇權時間價值。今天我只有做多,也
Thumbnail
因為工作的關係,需要在EXCEL產生和台股有關的資訊。 要抓取台股的方式有很多,譬如說用EXCEL 現在的功能從網頁匯入,但是畢竟愛寫程式的人就是因為懶,不想每次都用滑鼠點點點,所以就想要如何用VBA克服。 還好研究了一下,備齊以下幾個工具,就可以了。 (1)要有一個可以解析JSON格式的Li
Thumbnail
每日台股車況-24.03.14四 今日牛棚: 無 投資交易的方法、觀念、流派眾多,但把交易的流程拆解,可以簡化成以下步驟: 1.選股:                              2.決定買點(與加碼點) 上車 3.監控持股變化 4.決定賣點(與減碼點) 下車 ​5
Thumbnail
每日台股車況-24.03.11一 今日牛棚: 無 投資交易的方法、觀念、流派眾多,但把交易的流程拆解,可以簡化成以下步驟: 1.選股:                              2.決定買點(與加碼點) 上車 3.監控持股變化 4.決定賣點(與減碼點) 下車 ​5
這邊想提醒訂閱者,我之前講過我在觀察的股票,以及想分享給有做過作業的同學一些實戰的經驗。 我之前說過我在觀察證券股,若以後都超過三千億,可以佈局證券股。上周台股成交量已經放大到超過4千億,同時前幾天的新聞也提到證交稅收收入不錯,連幾個月漲。 我想大家可以參考一下。 同時,上次請大家做的作業,大
Thumbnail
台股籌碼的盤勢觀察中,主要以現貨、期貨和選擇權等不同的籌碼面向進行每日的分析,以掌握市場的變化。同時,透過指數貢獻度的觀察,清楚地了解盤勢的控盤走向。此外也將技術面和主力籌碼面結合,以篩選出市場中的重點股,這有助於更全面地理解市場動態。
Thumbnail
徵的就是你 🫵 超ㄅㄧㄤˋ 獎品搭配超瞎趴的四大主題,等你踹共啦!還有機會獲得經典的「偉士牌樂高」喔!馬上來參加本次的活動吧!
Thumbnail
隨著理財資訊的普及,越來越多台灣人不再將資產侷限於台股,而是將視野拓展到國際市場。特別是美國市場,其豐富的理財選擇,讓不少人開始思考將資金配置於海外市場的可能性。 然而,要參與美國市場並不只是盲目跟隨標的這麼簡單,而是需要策略和方式,尤其對新手而言,除了選股以外還會遇到語言、開戶流程、Ap
在此篇中,我們來拿實務的例子作實戰練習,我們會討論如何在Google Colab的環境下,撈取所有台美股的股票代碼,並獲取相關細節,最後將獲取的資訊存取於SQLite資料庫中。
Thumbnail
可能包含敏感內容
各位先進讀者好!台指選擇權課程將區分為三階段,看看哪一種方案最適合你學選擇權的投資。 #選擇權交易將會是未來台股投資最耀眼的商品 因為選擇權不需要在股海裡找出股王,也不需要99種技術分析,真正好的技術分析是自己練就出來的。本專欄已經有越來越多讀者在關注與私下聯繫各自的問題跟需求。如果有問
Thumbnail
透過分析臺灣好行的公開資料,分享如何用Python繪製折線圖
Thumbnail
我們先快速回顧今天的行情,籌碼分析要等到下午四點公佈數據之後才能在晚上寫一篇新的文章出來給讀者參考。這篇檢討務必看,我有保存珍貴資料 今日的行情從開盤到收盤,從最高點到最低點,一共造成800點的震盪行情。主力再度同時誘多與誘空,讓他的選擇權暴漲,同時做賣方吸取選擇權時間價值。今天我只有做多,也
Thumbnail
因為工作的關係,需要在EXCEL產生和台股有關的資訊。 要抓取台股的方式有很多,譬如說用EXCEL 現在的功能從網頁匯入,但是畢竟愛寫程式的人就是因為懶,不想每次都用滑鼠點點點,所以就想要如何用VBA克服。 還好研究了一下,備齊以下幾個工具,就可以了。 (1)要有一個可以解析JSON格式的Li
Thumbnail
每日台股車況-24.03.14四 今日牛棚: 無 投資交易的方法、觀念、流派眾多,但把交易的流程拆解,可以簡化成以下步驟: 1.選股:                              2.決定買點(與加碼點) 上車 3.監控持股變化 4.決定賣點(與減碼點) 下車 ​5
Thumbnail
每日台股車況-24.03.11一 今日牛棚: 無 投資交易的方法、觀念、流派眾多,但把交易的流程拆解,可以簡化成以下步驟: 1.選股:                              2.決定買點(與加碼點) 上車 3.監控持股變化 4.決定賣點(與減碼點) 下車 ​5
這邊想提醒訂閱者,我之前講過我在觀察的股票,以及想分享給有做過作業的同學一些實戰的經驗。 我之前說過我在觀察證券股,若以後都超過三千億,可以佈局證券股。上周台股成交量已經放大到超過4千億,同時前幾天的新聞也提到證交稅收收入不錯,連幾個月漲。 我想大家可以參考一下。 同時,上次請大家做的作業,大
Thumbnail
台股籌碼的盤勢觀察中,主要以現貨、期貨和選擇權等不同的籌碼面向進行每日的分析,以掌握市場的變化。同時,透過指數貢獻度的觀察,清楚地了解盤勢的控盤走向。此外也將技術面和主力籌碼面結合,以篩選出市場中的重點股,這有助於更全面地理解市場動態。