量化学习 | Tushare 基本面选股 (二)
量化投资比较重要的是策略,可是你得先选个好股,价值投资需要认同他的价值,值得投资的股票才有投资的机会,现在简单介绍一下基于基本面的选股,其实我现实生活中也有炒股,都是经验之说的选股原则。
首先从tushare中获取每日指标 pro.daily_basic
last_year = '20190101'
start_date = '20200313'
mytoken='your_token'
ts.set_token(mytoken)
pro = ts.pro_api()
df = pro.daily_basic(ts_code='', trade_date=start_date, fields='ts_code,trade_date,turnover_rate,volume_ratio,pe,pb')
P.S. 用户需要至少300积分才可以调取,我是学生进了官方群之后管理员帮我升级到了2000积分,所以大部分接口我都能使用。欢迎大家在我的链接下注册会送我积分:
https://tushare.pro/register?reg=355247
首先我们筛选PE为15以下的,PB为7一下的股票:
- PE是每股股价除以每股收益。如果股价是10元/股,每股收益是1元,PE就相当于10倍,你买这家公司的价钱相当于付出这家公司每年盈利的倍数。一般30以下才觉得可以接受。
- PB是每股股价除以每股净资产的倍数。如果股价是10元/股,净资产是5元/股,PB就是2倍,也相当于付出的是这个公司净资产的2倍。一般8以下可以接受,我这里调整成小一些,因为最近跌幅挺大的,所以很多公司跌破净资产。
PE_T = 15
PB_T = 1
df_choose = df[(df.pe<=PE_T)&(df.pb<=PB_T)]
符合条件的有198只股票,接着我们筛选一下近期公布的收益
收益可以通过pro.income接口查询:
income = []
for c in df_choose.ts_code:
df_income = pro.income(ts_code=c,start_date=last_year,end_date=start_date,fields='ts_code,ann_date,f_ann_date,end_date,report_type,comp_type,basic_eps,diluted_eps')
income.append(df_income['basic_eps'].iloc[0])
df_choose['basic_eps']=income
df_choose_good = df_choose[df_choose.basic_eps>1.0]
print(len(df_choose_good))
收益大于1.0的股票df_choose_good中含有23只股票
接着我想得出这些这些股票代码的股票名字,可以查询这个接口pro.stock_basic ,并且我存下该表格。
data_path = './data/'
if not os.path.exists(data_path):
os.makedirs(data_path)
csv_name = f'allname_data.csv'
csv_path = os.path.join(data_path,csv_name)
data = pro.stock_basic(exchange='', list_status='L', fields='ts_code,symbol,name,area,industry,list_date')
data.to_csv(csv_path, index=False)
data[data.ts_code.isin(df_choose_good.ts_code)]
| ts_code | symbol | name | area | industry | list_date | |
|---|---|---|---|---|---|---|
| 33 | 000042.SZ | 000042 | 中洲控股 | 深圳 | 全国地产 | 19940921 |
| 97 | 000501.SZ | 000501 | 鄂武商A | 湖北 | 百货 | 19921120 |
| 480 | 002024.SZ | 002024 | 苏宁易购 | 江苏 | 电器连锁 | 20040721 |
| 583 | 002128.SZ | 002128 | 露天煤业 | 内蒙 | 煤炭开采 | 20070418 |
| 600 | 002146.SZ | 002146 | 荣盛发展 | 河北 | 全国地产 | 20070808 |
| 2201 | 600000.SH | 600000 | 浦发银行 | 上海 | 银行 | 19991110 |
| 2211 | 600016.SH | 600016 | 民生银行 | 北京 | 银行 | 20001219 |
| 2247 | 600064.SH | 600064 | 南京高科 | 江苏 | 园区开发 | 19970506 |
| 2356 | 600188.SH | 600188 | 兖州煤业 | 山东 | 煤炭开采 | 19980701 |
| 2564 | 600449.SH | 600449 | 宁夏建材 | 宁夏 | 水泥 | 20030829 |
| 2770 | 600694.SH | 600694 | 大商股份 | 辽宁 | 百货 | 19931122 |
| 2773 | 600697.SH | 600697 | 欧亚集团 | 吉林 | 百货 | 19931206 |
| 2919 | 600859.SH | 600859 | 王府井 | 北京 | 百货 | 19940506 |
| 2964 | 600919.SH | 600919 | 江苏银行 | 江苏 | 银行 | 20160802 |
| 2965 | 600926.SH | 600926 | 杭州银行 | 浙江 | 银行 | 20161027 |
| 3034 | 601088.SH | 601088 | 中国神华 | 北京 | 煤炭开采 | 20071009 |
| 3062 | 601186.SH | 601186 | 中国铁建 | 北京 | 建筑工程 | 20080310 |
| 3076 | 601229.SH | 601229 | 上海银行 | 上海 | 银行 | 20161116 |
| 3111 | 601577.SH | 601577 | 长沙银行 | 湖南 | 银行 | 20180926 |
| 3134 | 601677.SH | 601677 | 明泰铝业 | 河南 | 铝 | 20110919 |
| 3157 | 601828.SH | 601828 | 美凯龙 | 上海 | 其他商业 | 20180117 |
| 3158 | 601838.SH | 601838 | 成都银行 | 四川 | 银行 | 20180131 |
| 3201 | 601997.SH | 601997 | 贵阳银行 | 贵州 | 银行 | 20160816 |
这个就是选出来的股,看来银行最近跌得挺厉害的,看好银行在后期反弹。


| ts_code | symbol | name | area | industry | list_date | |
|---|---|---|---|---|---|---|
| 0 | 000001.SZ | 1 | 平安银行 | 深圳 | 银行 | 19910403 |
| 140 | 000553.SZ | 553 | 安道麦A | 湖北 | 农药化肥 | 19931203 |
| 272 | 000732.SZ | 732 | 泰禾集团 | 福建 | 区域地产 | 19970704 |
| 2201 | 600000.SH | 600000 | 浦发银行 | 上海 | 银行 | 19991110 |
| 2210 | 600015.SH | 600015 | 华夏银行 | 北京 | 银行 | 20030912 |
| 2356 | 600188.SH | 600188 | 兖州煤业 | 山东 | 煤炭开采 | 19980701 |
| 2522 | 600383.SH | 600383 | 金地集团 | 深圳 | 全国地产 | 20010412 |
| 2608 | 600508.SH | 600508 | 上海能源 | 上海 | 煤炭开采 | 20010829 |
| 2770 | 600694.SH | 600694 | 大商股份 | 辽宁 | 百货 | 19931122 |
| 2852 | 600782.SH | 600782 | 新钢股份 | 江西 | 普钢 | 19961225 |
| 2919 | 600859.SH | 600859 | 王府井 | 北京 | 百货 | 19940506 |
| 3016 | 601009.SH | 601009 | 南京银行 | 江苏 | 银行 | 20070719 |
| 3057 | 601166.SH | 601166 | 兴业银行 | 福建 | 银行 | 20070205 |
| 3076 | 601229.SH | 601229 | 上海银行 | 上海 | 银行 | 20161116 |
| 3157 | 601828.SH | 601828 | 美凯龙 | 上海 | 其他商业 | 20180117 |
| 3201 | 601997.SH | 601997 | 贵阳银行 | 贵州 | 银行 | 20160816 |
量化学习 | Tushare 基本面选股 (二)的更多相关文章
- 金融量化之tushare模块的使用
一.TuShare简介和环境安装 TuShare是一个著名的免费.开源的python财经数据接口包.其官网主页为:TuShare -财经数据接口包.该接口包如今提供了大量的金融数据,涵盖了股票.基本面 ...
- 我的MYSQL学习心得(十二) 触发器
我的MYSQL学习心得(十二) 触发器 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数 ...
- css学习归纳总结(二) 转
原文地址:css学习归纳总结(二) 标签与元素 <p>标签和p元素有什么区别呢?大多数时候他们表示的是同一样东西,但仍有细微的区别.<p>.<div>等指的是HTM ...
- 【Unity Shaders】学习笔记——SurfaceShader(二)两个结构体和CG类型
[Unity Shaders]学习笔记——SurfaceShader(二)两个结构体和CG类型 转载请注明出处:http://www.cnblogs.com/-867259206/p/5596698. ...
- Linux进程间通信IPC学习笔记之同步二(SVR4 信号量)
Linux进程间通信IPC学习笔记之同步二(SVR4 信号量)
- Linux进程间通信IPC学习笔记之同步二(Posix 信号量)
Linux进程间通信IPC学习笔记之同步二(Posix 信号量)
- VSTO 学习笔记(十二)自定义公式与Ribbon
原文:VSTO 学习笔记(十二)自定义公式与Ribbon 这几天工作中在开发一个Excel插件,包含自定义公式,根据条件从数据库中查询结果.这次我们来做一个简单的测试,达到类似的目的. 即在Excel ...
- 我的MYSQL学习心得(十二)
原文:我的MYSQL学习心得(十二) 我的MYSQL学习心得(十二) 我的MYSQL学习心得(一) 我的MYSQL学习心得(二) 我的MYSQL学习心得(三) 我的MYSQL学习心得(四) 我的MYS ...
- Spring+SpringMVC+MyBatis深入学习及搭建(十二)——SpringMVC入门程序(一)
转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6999743.html 前面讲到:Spring+SpringMVC+MyBatis深入学习及搭建(十一)——S ...
随机推荐
- 关于angular跳转路由之后不能自动回到顶部的解决方法
Question: angular2 scroll top on router change 当我们在第一个路由滑动到底部当我们点击导航跳转到另一个路由时页面没有回到顶部而是保持上一个路由的滚动位置, ...
- <NOIP2005提高T2>过河の思路
emm又一道dp dp真有趣(你的良心呢?!!! Description 在河上有一座独木桥,一只青蛙想沿着独木桥从河的一侧跳到另一侧.在桥上有一些石子,青蛙很讨厌踩在这些石子上.由于桥的长度和青蛙一 ...
- 在python使用selenium获取动态网页信息并用BeautifulSoup进行解析--动态网页爬虫
爬虫抓取数据时有些数据是动态数据,例如是用js动态加载的,使用普通的urllib2 抓取数据是找不到相关数据的,这是爬虫初学者在使用的过程中,最容易发生的情况,明明在浏览器里有相应的信息,但是在pyt ...
- AngularJS入门篇
AngularJS是一个JavaScript框架,它通过指令扩展了HTML,且通过表达式绑定数据到 HTML.顺便一提,什么是框架?比如struts2.spring.hibernate.thinkph ...
- Introduction Of Gradient Descent
不是一个机器学习算法 是一种基于搜索的优化方法 作用:最小化一个损失函数 梯度上升法:最大化一个效用函数 import matplotlib.pyplot as plt import numpy as ...
- RHEL系统下安装atlassian-jira-5
操作系统:RHEL 6.4 x86_64 Jira版本:atlassian-jira-5.2.11-x64.bin 安装路径:/opt/atlassian/jira/ 数据保存路径:/opt/atla ...
- selenium+requests进行cookies保存读取操作
看这篇文章之前大家可以先看下我的上一篇文章:cookies详解 本篇我们就针对上一篇来说一下cookies的基本应用 使用selenium模拟登陆百度 from selenium import web ...
- Liferay7 Intellij IDEA 开发环境搭建
一.安装Liferay插件 安装过程不在赘述,推荐两种安装方式: 通过Intellij插件市场安装 通过下载插件zip包安装 安装完成后,在项目板块中点鼠标右键,会出现Liferay菜单. 二.安装L ...
- python django 之 django自带的分页
1. 例1: 基础的分页 1). vim app01/views.py def users(request): from django.core.pagina ...
- Enbale IE mode in Edge
1. 打开Edge, 在地址栏输入 edge://flags/ 2. 搜索 Enable IE Integration , 配置为 IE mode 3. 找到Edge的启动程序路径.如 C:\Prog ...