Python使用TuShare将股票数据保存到Oracle数据
TuShare是个获取股票数据的模块包,我们进行分析,需要将股票数据保存到本地,避免每次都从网上获取,由于本机装有ORCALE,以ORACLE为例介绍如何保存股票数据到本地。
一、大致思路:我们先获取沪深的所有股票信息,保存到数据库中,主要使用的是dataframe的to_sql函数。
to_sql(self, name, con, flavor='sqlite', schema=None, if_exists='fail',
index=True, index_label=None, chunksize=None, dtype=None):
if_exists参数值有三个,fail:如果表存在返回,append:在表后面追加数据;replace:把表替换掉
二、具体实现:
1、股票价格明细表
create table IQ_STOCK
(
op_time VARCHAR2(10),
open FLOAT,
high FLOAT,
close FLOAT,
low FLOAT,
volume FLOAT,
price_change FLOAT,
p_change FLOAT,
ma5 FLOAT,
ma10 FLOAT,
ma20 FLOAT,
v_ma5 FLOAT,
v_ma10 FLOAT,
v_ma20 FLOAT,
turnover FLOAT,
stockid VARCHAR2(10),
ktype VARCHAR2(1)
)
2、股票基本信息表
create table IQ_STOCK_BASE
(
code VARCHAR2(10),
name VARCHAR2(100),
industry VARCHAR2(100),
area VARCHAR2(100),
pe FLOAT,
outstanding FLOAT,
totals FLOAT,
"totalAssets" FLOAT,
"liquidAssets" FLOAT,
"fixedAssets" FLOAT,
reserved FLOAT,
"reservedPerShare" FLOAT,
esp FLOAT,
bvps FLOAT,
pb FLOAT,
"timeToMarket" NUMBER(19),
undp FLOAT,
perundp FLOAT,
rev FLOAT,
profit FLOAT,
gpr FLOAT,
npr FLOAT,
holders NUMBER(19)
)
3、先获取股票的基本信息:
def Get_Stock_List():
##取得股票基本信息
df = ts.get_stock_basics()
#股票数据保存
engine = create_engine('oracle+cx_oracle://user:password@localhost/orcl')
cnx = engine.connect()
##先清空
strSql = 'truncate table iq_stock_base'
cnx.execute(strSql)
df.to_sql('iq_stock_base', cnx,if_exists='append',chunksize=500)
cnx.close()
return df
4、更新近30天的K线数据,此处更新的是周K线
def Update_StockData():
##开始日期 format:YYYY-MM-DD 为空时取到API所提供的最早日期数据
p_start=time.strftime('%Y-%m-%d',time.localtime(time.time()-24*60*60*30))
p_ktype='W'
#股票数据保存
engine = create_engine('oracle+cx_oracle://xulp:yiyi2009A!@localhost/orcl')
cnx = engine.connect()
#取出股票基本数据
result=pd.read_sql('select * from iq_stock_base',cnx)
for row in result['code']:
try:
##避免重复先删除
strSql = 'delete from iq_stock where stockid=\'{}\' and ktype=\'{}\' and op_time>=\'{}\''.format(row,p_ktype,p_start)
cnx.execute(strSql)
df=ts.get_hist_data(code=row,start=p_start,ktype=p_ktype)
df.index.names = ['op_time']
df['STOCKID']= row
df['ktype']= p_ktype
df.to_sql('iq_stock', cnx,if_exists='append')
print('code:{}'.format(row))
except:
print('Exception',":",row)
cnx.close()
Python使用TuShare将股票数据保存到Oracle数据的更多相关文章
- 快速将excel数据保存到Oracle数据库中【转】
我们在工作中,也许会碰到以下情况,客户或者同事发来需要调查的数据,并不是dmp文件,而是excel文件,此时通常是一张表,少量几条记录.最近我恰好碰到了这种情况,所以做了些调查,不敢藏私,拿出来跟大家 ...
- 吴裕雄--天生自然python数据清洗与数据可视化:MYSQL、MongoDB数据库连接与查询、爬取天猫连衣裙数据保存到MongoDB
本博文使用的数据库是MySQL和MongoDB数据库.安装MySQL可以参照我的这篇博文:https://www.cnblogs.com/tszr/p/12112777.html 其中操作Mysql使 ...
- 1.scrapy爬取的数据保存到es中
先建立es的mapping,也就是建立在es中建立一个空的Index,代码如下:执行后就会在es建lagou 这个index. from datetime import datetime fr ...
- 我用C#调用C编译的dll中有这样一个函数,函数大概的功能就是把数据保存到buf缓冲区中:
我用C#调用C编译的dll中有这样一个函数,函数大概的功能就是把数据保存到buf缓冲区中: C/C++ code ? 1 int retrieve(int scanno,void* buf); 在 ...
- Excel文件数据保存到SQL中
1.获取DataTable /// <summary> /// 查询Excel文件中的数据 /// </summary> /// <param name="st ...
- 将爬取的数据保存到mysql中
为了把数据保存到mysql费了很多周折,早上再来折腾,终于折腾好了 安装数据库 1.pip install pymysql(根据版本来装) 2.创建数据 打开终端 键入mysql -u root -p ...
- mysql触发器的使用 想让b字段在更新的时候把旧数据保存到a字段中
使用mysql希望数据库自动触发一些规则,进行更新数据的时候,就需要用触发器了,比如 将旧数据保存到额外字段中,如何做呢? 在abc表中 name更新的时候 我希望把name的老数据保存到 old_n ...
- 简单抓取安居客房产数据,并保存到Oracle数据库
思路和上一篇差不多,先获取网站html文件,使用BeautifulSoup进行解析,将对应属性取出,逐一处理,最后把整理出的记录保存到oracle中,持久化储存. '''Created on 2017 ...
- 为什么查询出来的数据保存到Arraylist?插入删除数据为啥用LinkedList?
引言:这是我在回答集合体系时,被问到的一个问题,也是因为没有深入学习所以回答的并不是很好,所以这两天看了一下,以下是我的一些回答与学习方法. 学习方法:我们学习,系统性的学习肯定是比零散的学习更有效的 ...
随机推荐
- Keepalived的安装
Keepalived的安装 官网下载:点击直达 yum install -y libnl yum install -y libnl-devel 下载 cd /usr/local/src/ wget h ...
- C#定义类型转化 及 格式化字符串
operator 关键字 operator 关键字用来重载内置运算符,或提供类/结构声明中的用户定义转换.它可以定义不同类型之间采用何种转化方式和转化的结果. operator用于定义类型转化时可采用 ...
- 一个脚本可以一直运行 ignore_user_abort
php中ignore_user_abort函数的用法 PHP中的ignore_user_abort函数是当用户关掉终端后脚本不停止仍然在执行,可以用它来实现计划任务与持续进程,下面会通过实例讨论ign ...
- C#获取本地IP地址[常用代码段]
获得当前机器的IP代码,假设本地主机为单网卡 string strHostName = Dns.GetHostName(); //得到本机的主机名 IPHostEntry ipEntry = Dns. ...
- UICollectionViewCell 网格显示数据
using System; using System.Collections.Generic; using Foundation; using UIKit; namespace ddd { publi ...
- UTF-8编码的空格(194 160)问题
前台的字符串传递到后台进行处理,发现了一个较诡异的问题:字符串中的一个空格(ASCII:32)被UTF-8编码之后变成了一个诡异的字符(ASCII:194 和 160的组合)!但在后台其表象还是空格. ...
- springmvc 格式化使用Jackjson格式化报Failed to write HTTP message
Failed to write HTTP message: org.springframework.http.converter.HttpMessageNotWritableException: Co ...
- web前端基础知识-(六)web框架
一.web框架本质 众所周知,对于所有的Web应用,本质上其实就是一个socket服务端,用户的浏览器其实就是一个socket客户端. #!/usr/bin/env python #coding:ut ...
- ASCII码而已
题目: \u5927\u5bb6\u597d\uff0c\u6211\u662f\u0040\u65e0\u6240\u4e0d\u80fd\u7684\u9b42\u5927\u4eba\uff01 ...
- UP Board 妄图启动ubilinux失败
前言 原创文章,转载引用务必注明链接. 经历了上次的上电开机失败,我们终于发现需要手动为UP板安装系统,因为没有显示器的Headless模式时,使用Linux比较方便,另外熟悉Debian系的,所以选 ...