想买低价股?看看利用Python对A股低价股的一些数据分析!

大盘不稳,高价股让人心惊,想换点低价股试试水?

新手模拟交易玩腻了,想试试实盘炒股又怕风险太大,考虑从低价股入手?

别看着股价低就下手,看看下面对一些低价股的简单筛选和分析,或许对你有所帮助。

系统环境:Python+Tushare+Matplotlib

一、获取行情数据

import tushare as ts

# 获取实时行情数据
hq = ts.get_today_all()
# 节选出股票代码code、名称name、涨跌幅changepercent、股价trade
hq = hq[['code','name','changepercent','trade']]

# 筛选出当前股价高于0元低于3元的股票信息
mins = hq.trade>0.00
maxs = hq.trade<=2.99
allselect = mins & maxs
data = hq[allselect].sort('trade')

得到股价小于3元的低价股票信息,然后对深圳成指和异常股票进行剔除:

# 提取低价股股票代码,并剔除深圳成指股票
code_list = []
for c in data.code:
    if c[0] != "0":
        code_list.append(c)
code_list

得到九只股票的代码

['600401',
 '601005',
 '600022',
 '601558',
 '601258',
 '601880',
 '600307',
 '600282',
 '600231'

然后获取2014-12-01至2016-12-01上证指数的历史行情数据:

# 获取2014-12-01至2016-12-01的上证指数历史行情数据
sh_hist_data = ts.get_hist_data(code='sh',start='2014-12-01',end='2016-12-01')
sh_hist_data = sh_hist_data[['open','high','close','low','volume','price_change','p_change']].sort_index()

引入matplotlib模块:

import matplotlib.pyplot as plt
from matplotlib.pylab import datestr2num
import matplotlib
# 设置中文字体
font = matplotlib.font_manager.FontProperties(fname='C:\Windows\Fonts\simsun.ttc')

二、对比上证指数每日最低价和各只低价股每日最低价的价格走势

%matplotlib inline
sh_hist_data.head(10)
dates = [datestr2num(i) for i in sh_hist_data.index]
plt.figure(figsize=(40,30))
# 新建一个子图,绘制上证指数走势
plt.subplot(311)
plt.title("2014年12月1日至2016年12月1日上证指数最低价走势",fontsize=30)
plt.xticks(rotation=20,fontsize=26)
plt.yticks(fontsize=26)
plt.plot_date(dates,sh_hist_data.low,'-',linewidth=2.5)
plt.grid(True)
# 遍历低价股代码列表,绘制股价走势
for i in code_list[0:4]:
    hist_data = ts.get_hist_data(code=i,start='2014-12-01',end='2016-12-01')
    code_data = hist_data[['open','high','close','low','volume','price_change','p_change']].sort_index()
    dates = [datestr2num(t) for t in code_data.index]
    plt.subplot(312)
    plt.title("2014年12月1日至2016年12月1日各低价股最低价走势",fontsize=30)
    plt.xticks(rotation=20,fontsize=26)
    plt.yticks(fontsize=26)
    plt.plot_date(dates,code_data['low'],'-',linewidth=2.5,label=i)
    plt.legend(loc=1,fontsize=22)
    plt.grid(True)
for i in code_list[4:]:
    hist_data = ts.get_hist_data(code=i,start='2014-12-01',end='2016-12-01')
    code_data = hist_data[['open','high','close','low','volume','price_change','p_change']].sort_index()
    dates = [datestr2num(t) for t in code_data.index]
    plt.subplot(313)
    plt.title("2014年12月1日至2016年12月1日各低价股最低价价走势",fontsize=30)
    plt.xticks(rotation=20,fontsize=26)
    plt.yticks(fontsize=26)
    plt.plot_date(dates,code_data['low'],'-',linewidth=2.5,label=i)
    plt.legend(loc=1,fontsize=22)
    plt.grid(True)

得到以下图表:

看两年的最低价走势,与上证大盘走势最不吻合的股票有:601258、600231、601880、600401

三、对比各股历史平均成交量:

# 对各低价股的历史平均成交量做可视化处理
import numpy as np
font = matplotlib.font_manager.FontProperties(fname='C:\Windows\Fonts\simsun.ttc')
codes = []
volumes = []
for i in code_list:
    histdata = ts.get_hist_data(code=i,start='2014-12-01',end='2016-12-01')
    volume_data = histdata['volume'].mean()/10000
    codes.append(i)
    volumes.append(volume_data)
#     print(codes,volumes)
x = np.arange(len(codes))
# 获取各只股票平均成交量的平均值
mean_volume = float(sum(volumes)/len(volumes))
# 将成交量均值绘制一条直线
plt.axhline(y=mean_volume,color='r')
plt.xticks(x,codes,rotation=45)
plt.title("各低价股两年平均成交量比较")
plt.bar(x,volumes,0.5,color='teal')
plt.xlabel("股票代码",fontproperties=font)
plt.ylabel("平均成交量(万元)",fontproperties=font)
plt.grid(True)

得到如下柱状图:

两年平均成交量约为100(万元)

在其之上的股票有:600401、600307、600010

两年平均成交量最低的为:600231

四、对比上证和各股两年涨跌幅:

# 上证指数及各低价股两年涨跌幅
p_changes = []
codes = []
sh_change = sh_hist_data.p_change.sum()
for i in code_list:
    code_change = ts.get_hist_data(code=i,start='2014-12-01',end='2016-12-01').p_change.sum()
    codes.append(i)
    p_changes.append(code_change)
codes[-1] = "上证"
p_changes[-1] = sh_change
x = np.arange(len(codes))
plt.axvline(x=sh_change,color='r')
plt.title('上证及各低价股两年涨跌幅')
plt.yticks(x,codes)
plt.xlabel("涨幅(百分比)")
# plt.barh([10],[sh_change],color='r')
rets = plt.barh(x,p_changes,color='sage',align="center")
plt.grid(True)

上证两年的涨跌幅为30%

涨幅在此之下的股票有:601258、601005、600401

五、对比各股两年的平均换手率:

# 各低价股的换手率对比
codes = []
tur = []
for i in code_list:
    # 获取两年的历史行情数据
    turnovers = ts.get_hist_data(code=i,start='2014-12-01',end='2016-12-01').turnover
    # 获取存在数据天数
    t_days = len(turnovers)
    # 对换手率进行相加
    turnovers = turnovers.sum()
    # 计算平均换手率
    avg_tur = turnovers/t_days
    codes.append(i)
    tur.append(avg_tur)
x = np.arange(len(codes))
plt.title("各低价股两年平均换手率")
plt.yticks(x,codes)
plt.barh(x,tur,color='darkslategrey',align='center')
plt.grid(True)

两年平均换手率最高的为:601005重庆钢铁

两年平均换手率最低的为:600022山东钢铁

嗯,简单的筛选就已经结束了,不知道你心里有没有心仪的低价股了?

原文发布于微信公众号 - 州的先生(zmister2016)

原文发表时间:2016-12-08

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏腾讯云安全的专栏

鉴黄界的“Master”,其实是“他”

1984
来自专栏DT数据侠

春节抢票的最佳时机,都在这350亿机票价格数据里了

对于旅游或者探亲来说,买机票的一个最基本的问题是什么时候能买到最便宜的机票?提前一个月还是一周?网络上各种旅游“业内人士”也说提前一个月可能买到最便宜的机票,有...

680
来自专栏程序员Gank

机票大数据分析,揭示购票的秘密

对于旅游或者探亲来说,买机票的一个最基本的问题是什么时候买能买到最便宜的机票?提前一个月还是一周?知乎上各种旅游攻略上各种“业内人士”也说提前一个月买可能买到最...

833
来自专栏ATYUN订阅号

超级计算模拟和机器学习:使用更加清洁高效的工作流体发电

在传统的蒸汽动力装置中,剩余的水必须与发电蒸汽分开。这一过程限制了效率,而在早期的发电厂,可能会发生剧烈的变化,导致爆炸。在20世纪20年代,Mark Bens...

852
来自专栏数据的力量

如何学习统计学

923
来自专栏数据的力量

用工程师的思维加上 3D 建模,熬出一碗浓浓的鸡汤

1393
来自专栏量子位

不好,两群AI打起来了!“幕后主使”是上海交大~

夏乙 若朴 发自 凹非寺 量子位 出品 | 公众号 QbitAI 你们这些科学家在干什么!怎么教会AI打群架啦! ? 成百上千的AI agent,分成两支AI大...

3775
来自专栏新智元

川普PK希拉里,谁演讲技术更好?这里有一个AI做的测试

来源:foxnews.com 作者:Brooke Crothers 编译:刘小芹 【新智元导读】最近Trint公司做了一个测试,用它的AI软件对特朗普、克林顿...

33812
来自专栏大数据文摘

暮光女主发AI“论文”?维密超模学编程?女神跨界靠干货还是颜值?

2165
来自专栏大数据文摘

可视化经典:10幅精妙绝伦的科学视图

992

扫码关注云+社区