本文目錄一覽:
python的量化代碼怎麼用到股市中
2010 ~ 2017 滬深A股各行業量化分析
在開始各行業的量化分析之前,我們需要先弄清楚兩個問題:
第一,A股市場上都有哪些行業;
第二,各行業自2010年以來的營收、凈利潤增速表現如何?
第一個問題
很好回答,我們使用JQData提供的獲取行業成分股的方法,輸入get_industries(name=’sw_l1′)
得到申萬一級行業分類結果如下:它們分別是:【農林牧漁、採掘、化工、鋼鐵、有色金屬、電子、家用電器、食品飲料、紡織服裝、輕工製造、醫藥生物、公用事業、交通運輸、房地產、商業貿易、休閑服務、綜合、建築材料、建築裝飾、電器設備、國防軍工、計算機、傳媒、通信、銀行、非銀金融、汽車、機械設備】共計28個行業。
第二個問題
要知道各行業自2010年以來的營收、凈利潤增速表現,我們首先需要知道各行業在各個年度都有哪些成分股,然後加總該行業在該年度各成分股的總營收和凈利潤,就能得到整個行業在該年度的總營收和總利潤了。這部分數據JQData也為我們提供了方便的介面:通過調用get_industry_stocks(industry_code=『行業編碼』, date=『統計日期』),獲取申萬一級行業指定日期下的行業成分股列表,然後再調用查詢財務的數據介面:get_fundamentals(query_object=『query_object』, statDate=year)來獲取各個成分股在對應年度的總營收和凈利潤,最後通過加總得到整個行業的總營收和總利潤。這裡為了避免非經常性損益的影響,我們對凈利潤指標最終選取的扣除非經常性損益的凈利潤數據。
我們已經獲取到想要的行業數據了。接下來,我們需要進一步分析,這些行業都有什麼樣的增長特徵。
我們發現,在28個申萬一級行業中,有18個行業自2010年以來在總營收方面保持了持續穩定的增長。它們分別是:【農林牧漁,電子,食品飲料,紡織服裝,輕工製造,醫藥生物,公用事業,交通運輸,房地產,休閑服務,建築裝飾,電氣設備,國防軍工,計算機,傳媒,通信,銀行,汽車】;其他行業在該時間範圍內出現了不同程度的負增長。
那麼,自2010年以來凈利潤保持持續增長的行業又會是哪些呢?結果是只有5個行業保持了基業長青,他們分別是醫藥生物,建築裝飾,電氣設備,銀行和汽車。(註:由於申萬行業在2014年發生過一次大的調整,建築裝飾,電氣設備,銀行和汽車實際從2014年才開始統計。)
從上面的分析結果可以看到,真正能夠保持持續穩定增長的行業並不多,如果以扣非凈利潤為標準,那麼只有醫藥生物,建築裝飾,電氣設備,銀行和汽車這五個行業可以稱之為優質行業,實際投資中,就可以只從這幾個行業中去投資。這樣做的目的是,一方面,能夠從行業大格局層面避免行業下行的風險,繞開一個可能出現負增長的的行業,從而降低投資的風險;另一方面,也大大縮短了我們的投資範圍,讓投資者能夠專註於從真正好的行業去挑選公司進行投資。
「2010-2017」投資於優質行業龍頭的收益表現
選好行業之後,下面進入選公司環節。我們知道,即便是一個好的行業也仍然存在表現不好的公司,那麼什麼是好的公司呢,本文試圖從營業收入規模和利潤規模和來考察以上五個基業長青的行業,從它們中去篩選公司作為投資標的。
3.1按營業收入規模構建的行業龍頭投資組合
首先,我們按照營業收入規模,篩選出以上5個行業【醫藥生物,建築裝飾,電氣設備,銀行和汽車】從2010年至今的行業龍頭如下表所示:
可以看到,雖然時間跨度很長,但是在這5個行業中,營收規模大的公司始終處於領先地位。它們分別是【上海醫藥,中國建築,上海電氣,工商銀行,上汽集團】。
由於各年度上市公司年報的公布截止日是4月30日,待所有上市公司年報公布後,確定行業龍頭,然後將這些行業龍頭構建成一個投資組合。那麼,持有投資組合的收益表現如何呢?為了保證投資時間的一致性,我們假設從2015年4月30號之後的第一個交易日開始投資,本金是100萬,每個標的投資權重相同,都是20%,並且忽略交易成本,那麼持有該組合至2018年4月30號的投資收益是多少呢?
我們利用JQData提供的獲取行情介面get_price(security=’股票代碼’, start_date=’開始交易日’, end_date=’投資截止日’, frequency=’daily’, fields=None, skip_paused=False, fq=’pre’),分別獲取組合中各個公司在各年度開始交易日和投資截止日(4.30之後的第一個交易日)的價格,得到最終的投資結果如下圖所示:
可以看到,除了2015.5.4-2016.5.3股災期間,該組合投資收益率和上證指數、滬深300指數有一個同步的大幅下跌外,從2016.5.3至2018年5.2,改組合連續兩年獲得了正收益,並在2016年大幅跑贏另外兩個基準指數20%以上。
聰明的讀者一定會問這樣一個問題,如果我從2018年5月2號開始,投資100萬買入這樣一個按營收規模衡量的行業龍頭組合,至2018年5月30號,收益表現會如何呢?答案是【3.04%】,而同期上證指數收益率和滬深300收益率分別是【-0.20%】和【-0.39%】,可以說表現非常之好了。具體收益如下表所示:
3.2按扣非凈利潤規模構建的行業龍頭投資組合
如果我們按照扣除非經常性損益的凈利潤來衡量,以上5個行業從2010年至今的行業龍頭又會是哪些呢,我們查出來如下表所示:
可以看到,按照扣非凈利潤來構建投資組合,醫藥生物和電氣設備兩個行業分別發生了行業龍頭的更替,如果要構建基於扣非凈利潤的投資組合,那麼我們就需要每年去調整我們的組合標的以保證組合中都是上一年度的行業龍頭。和上述投資回測方式一樣,我們從2015年5月4號買入這樣一個組合,並在之後每年4月30號之後的第一個交易日調整組合中的行業龍頭標的,最終的投資結果如下表所示:
可以看到,即使是2015.4.30-2016.5.3股災期間,該組合也跑贏上證指數和滬深300指數3%左右;而2016.5.3至2018年5.2期間更是大幅跑贏兩個基準指數高達30%以上。
同樣的,如果從2018年5月2號開始,投資100萬買入這樣一個按扣非凈利潤規模衡量的行業龍頭組合,至2018年5月30號,收益表現會如何呢?答案是【2.83%】,對比同期上證指數收益率和滬深300指數的【-0.20%】和【-0.39%】,仍然維持了非常良好的表現。具體收益如下表所示:
結論
通過以上行業分析和投資組合的歷史回測可以看到:
先選行業,再選公司,即使是從2015年股災期間開始投資,至2018年5月1號,仍然能夠獲得相對理想的收益,可以說,紅杉資本的賽道投資法則對於一般投資者還是比較靠譜的。
在構建行業龍頭投資組合時,凈利潤指標顯著優於營業收入指標,獲得的投資收益能夠更大的跑贏全市場收益率
市場是不斷波動的,如果一個投資者從股災期間開始投資,那麼即使他買入了上述優質行業的龍頭組合,在近3年也只能獲得12%左右的累計收益;而如果從2016年5月3日開始投資,那麼至2018年5月2日,2年時間就能獲得超過50%以上的收益了。所以,在投資過程中選擇時機也非常重要。
出自:JoinQuant 聚寬數據 JQData
Python量化教程:不得不學的K線圖「代碼複製可用」
不管是對量化分析師還是普通的投資者來說,K線圖(蠟燭圖)都是一種很經典、很重要的工具。在K線圖中,它會繪製每天的最高價、最低價、開盤價和收盤價,這對於我們理解股票的趨勢以及每天的多空對比很有幫助。
一般來說,我們會從各大券商平台獲取K線圖,但是這種情況下獲得的K線圖往往不能靈活調整,也不能適應複雜多變的生產需求。因此我們有必要學習一下如何使用Python繪製K線圖。
需要說明的是,這裡mpl_finance是原來的matplotlib.finance,但是現在獨立出來了(而且好像沒什麼人維護更新了),我們將會使用它提供的方法來繪製K線圖;tushare是用來在線獲取股票數據的庫;matplotlib.ticker中有個FuncFormatter()方法可以幫助我們調整坐標軸;matplotlib.pylab.date2num可以幫助我們將日期數據進行必要的轉化。
我們以上證綜指18年9月份以來的行情為例。
我們先使用mpl_finance繪製一下,看看是否一切正常。
可以看到,所有的節假日包括周末,在這裡都會顯示為空白,這對於我們圖形的連續性非常不友好,因此我們要解決掉他們。
可以看到,空白問題完美解決,這裡我們解釋一下。由於matplotlib會將日期數據理解為 連續數據 ,而連續數據之間的間距是有意義的,所以非交易日即使沒有數據,在坐標軸上還是會體現出來。連續多少個非交易日,在坐標軸上就對應了多少個小格子,但這些小格子上方並沒有相應的蠟燭圖。
明白了它的原理,我們就可以對症下藥了。我們可以給橫坐標(日期)傳入連續的、固定間距的數據,先保證K線圖的繪製是連續的;然後生成一個保存有正確日期數據的列表,接下來,我們根據坐標軸上的數據去取對應的正確的日期,並替換為坐標軸上的標籤即可。
上邊format_date函數就是這個作用。由於前邊我們給dates列生成了從0開始的序列連續數據,因此我們可以直接把它當作索引,從真正的日期列表裡去取對應的數據。在這裡我們要使用matplotlib.ticker.FuncFormattter()方法,它允許我們指定一個格式化坐標軸標籤的函數,在這個函數里,我們需要接受坐標軸的值以及位置,並返回自定義的標籤。
你學會了嗎?
當然,一個完整的K線圖到這裡並沒有結束,後邊我們會考慮加入均線、成交量等元素,感興趣的同學歡迎關注哦!
python對股票分析有什麼作用
你好,Python對於股票分析來說,用處是很大的
Python,用數據軟體分析可以做股票的量化程序,因為股票量化是未來的一種趨勢,能夠解決人為心理波動和衝動下單等不良行為,所以學好python量化的話,那麼對股票來說有很大很大幫助
怎麼學習python量化交易?
下面教你八步寫個量化交易策略——單股票均線策略
1 確定策略內容與框架
若昨日收盤價高出過去20日平均價今天開盤買入股票
若昨日收盤價低於過去20日平均價今天開盤賣出股票
只操作一隻股票,很簡單對吧,但怎麼用代碼說給計算機聽呢?
想想人是怎麼操作的,應該包括這樣兩個部分
既然是單股票策略,事先決定好交易哪一個股票。
每天看看昨日收盤價是否高出過去20日平均價,是的話開盤就買入,不是開盤就賣出。每天都這麼做,循環下去。
對應代碼也是這兩個部分
def initialize(context):
用來寫最開始要做什麼的地方
def handle_data(context,data):
用來寫每天循環要做什麼的地方
2 初始化
我們要寫設置要交易的股票的代碼,比如 兔寶寶(002043)
def initialize(context):
g.security = ‘002043.XSHE’# 存入兔寶寶的股票代碼
3 獲取收盤價與均價
首先,獲取昨日股票的收盤價
# 用法:變數 = data[股票代碼].close
last_price = data[g.security].close# 取得最近日收盤價,命名為last_price
然後,獲取近二十日股票收盤價的平均價
# 用法:變數 = data[股票代碼].mavg(天數,『close』)
# 獲取近二十日股票收盤價的平均價,命名為average_price
average_price = data[g.security].mavg(20, ‘close’)
4 判斷是否買賣
數據都獲取完,該做買賣判斷了
# 如果昨日收盤價高出二十日平均價, 則買入,否則賣出
if last_price average_price:
買入
elif last_price average_price:
賣出
問題來了,現在該寫買賣下單了,但是拿多少錢去買我們還沒有告訴計算機,所以每天還要獲取賬戶里現金量。
# 用法:變數 = context.portfolio.cash
cash = context.portfolio.cash# 取得當前的現金量,命名為cash
5 買入賣出
# 用法:order_value(要買入股票股票的股票代碼,要多少錢去買)
order_value(g.security, cash)# 用當前所有資金買入股票
# 用法:order_target(要買賣股票的股票代碼,目標持倉金額)
order_target(g.security, 0)# 將股票倉位調整到0,即全賣出
6 策略代碼寫完,進行回測
把買入賣出的代碼寫好,策略就寫完了,如下
def initialize(context):#初始化
g.security = ‘002043.XSHE’# 股票名:兔寶寶
def handle_data(context, data):#每日循環
last_price = data[g.security].close# 取得最近日收盤價
# 取得過去二十天的平均價格
average_price = data[g.security].mavg(20, ‘close’)
cash = context.portfolio.cash# 取得當前的現金
# 如果昨日收盤價高出二十日平均價, 則買入,否則賣出。
if last_price average_price:
order_value(g.security, cash)# 用當前所有資金買入股票
elif last_price average_price:
order_target(g.security, 0)# 將股票倉位調整到0,即全賣出
現在,在策略回測界面右上部,設置回測時間從20140101到20160601,設置初始資金100000,設置回測頻率,然後點擊運行回測。
7 建立模擬交易,使策略和行情實時連接自動運行
策略寫好,回測完成,點擊回測結果界面(如上圖)右上部紅色模擬交易按鈕,新建模擬交易如下圖。 寫好交易名稱,設置初始資金,數據頻率,此處是每天,設置好後點提交。
8 開啟微信通知,接收交易信號
點擊聚寬導航欄我的交易,可以看到創建的模擬交易,如下圖。 點擊右邊的微信通知開關,將OFF調到ON,按照指示掃描二維碼,綁定微信,就能微信接收交易信號了。
原創文章,作者:LVOC,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/139760.html