量化投资比较重要的是策略,可是你得先选个好股,价值投资需要认同他的价值,值得投资的股票才有投资的机会,现在简单介绍一下基于基本面的选股,其实我现实生活中也有炒股,都是经验之说的选股原则。

首先从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 基本面选股 (二)的更多相关文章

  1. 金融量化之tushare模块的使用

    一.TuShare简介和环境安装 TuShare是一个著名的免费.开源的python财经数据接口包.其官网主页为:TuShare -财经数据接口包.该接口包如今提供了大量的金融数据,涵盖了股票.基本面 ...

  2. 我的MYSQL学习心得(十二) 触发器

    我的MYSQL学习心得(十二) 触发器 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数 ...

  3. css学习归纳总结(二) 转

    原文地址:css学习归纳总结(二) 标签与元素 <p>标签和p元素有什么区别呢?大多数时候他们表示的是同一样东西,但仍有细微的区别.<p>.<div>等指的是HTM ...

  4. 【Unity Shaders】学习笔记——SurfaceShader(二)两个结构体和CG类型

    [Unity Shaders]学习笔记——SurfaceShader(二)两个结构体和CG类型 转载请注明出处:http://www.cnblogs.com/-867259206/p/5596698. ...

  5. Linux进程间通信IPC学习笔记之同步二(SVR4 信号量)

    Linux进程间通信IPC学习笔记之同步二(SVR4 信号量)

  6. Linux进程间通信IPC学习笔记之同步二(Posix 信号量)

    Linux进程间通信IPC学习笔记之同步二(Posix 信号量)

  7. VSTO 学习笔记(十二)自定义公式与Ribbon

    原文:VSTO 学习笔记(十二)自定义公式与Ribbon 这几天工作中在开发一个Excel插件,包含自定义公式,根据条件从数据库中查询结果.这次我们来做一个简单的测试,达到类似的目的. 即在Excel ...

  8. 我的MYSQL学习心得(十二)

    原文:我的MYSQL学习心得(十二) 我的MYSQL学习心得(十二) 我的MYSQL学习心得(一) 我的MYSQL学习心得(二) 我的MYSQL学习心得(三) 我的MYSQL学习心得(四) 我的MYS ...

  9. Spring+SpringMVC+MyBatis深入学习及搭建(十二)——SpringMVC入门程序(一)

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6999743.html 前面讲到:Spring+SpringMVC+MyBatis深入学习及搭建(十一)——S ...

随机推荐

  1. 关于angular跳转路由之后不能自动回到顶部的解决方法

    Question: angular2 scroll top on router change 当我们在第一个路由滑动到底部当我们点击导航跳转到另一个路由时页面没有回到顶部而是保持上一个路由的滚动位置, ...

  2. <NOIP2005提高T2>过河の思路

    emm又一道dp dp真有趣(你的良心呢?!!! Description 在河上有一座独木桥,一只青蛙想沿着独木桥从河的一侧跳到另一侧.在桥上有一些石子,青蛙很讨厌踩在这些石子上.由于桥的长度和青蛙一 ...

  3. 在python使用selenium获取动态网页信息并用BeautifulSoup进行解析--动态网页爬虫

    爬虫抓取数据时有些数据是动态数据,例如是用js动态加载的,使用普通的urllib2 抓取数据是找不到相关数据的,这是爬虫初学者在使用的过程中,最容易发生的情况,明明在浏览器里有相应的信息,但是在pyt ...

  4. AngularJS入门篇

    AngularJS是一个JavaScript框架,它通过指令扩展了HTML,且通过表达式绑定数据到 HTML.顺便一提,什么是框架?比如struts2.spring.hibernate.thinkph ...

  5. Introduction Of Gradient Descent

    不是一个机器学习算法 是一种基于搜索的优化方法 作用:最小化一个损失函数 梯度上升法:最大化一个效用函数 import matplotlib.pyplot as plt import numpy as ...

  6. RHEL系统下安装atlassian-jira-5

    操作系统:RHEL 6.4 x86_64 Jira版本:atlassian-jira-5.2.11-x64.bin 安装路径:/opt/atlassian/jira/ 数据保存路径:/opt/atla ...

  7. selenium+requests进行cookies保存读取操作

    看这篇文章之前大家可以先看下我的上一篇文章:cookies详解 本篇我们就针对上一篇来说一下cookies的基本应用 使用selenium模拟登陆百度 from selenium import web ...

  8. Liferay7 Intellij IDEA 开发环境搭建

    一.安装Liferay插件 安装过程不在赘述,推荐两种安装方式: 通过Intellij插件市场安装 通过下载插件zip包安装 安装完成后,在项目板块中点鼠标右键,会出现Liferay菜单. 二.安装L ...

  9. python django 之 django自带的分页

    1. 例1: 基础的分页    1). vim app01/views.py        def users(request):            from django.core.pagina ...

  10. Enbale IE mode in Edge

    1. 打开Edge, 在地址栏输入 edge://flags/ 2. 搜索 Enable IE Integration , 配置为 IE mode 3. 找到Edge的启动程序路径.如 C:\Prog ...