-
Notifications
You must be signed in to change notification settings - Fork 26
Expand file tree
/
Copy pathMain_SaveStockData2LocalTest.m
More file actions
330 lines (314 loc) · 9.93 KB
/
Main_SaveStockData2LocalTest.m
File metadata and controls
330 lines (314 loc) · 9.93 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
%% Main_SaveStockData2LocalTest
% by LiYang_faruto
% Email:farutoliyang@foxmail.com
% 2014/12/12
%% A Little Clean Work
tic;
% clear;
% clc;
% close all;
format compact;
%% 日志文件
fid = fopen('Dlog.txt','at+');
str = ['日期时间:',datestr(now),' 操作记录日志by李洋faruto '];
fprintf(fid,'%s\n',str);
%% 获取股票代码列表
run = 0;
if 1 == run
try
[StockList,StockListFull] = GetStockList_Web;
save('StockList','StockList');
str = ['日期时间:',datestr(now),' 更新股票代码列表'];
fprintf(fid,'%s\n',str);
catch err
str = ['日期时间:',datestr(now),' 更新股票代码列表失败:',err.message];
fprintf(fid,'%s\n',str);
for i = 1:size(err.stack,1)
str = ['FunName:',err.stack(i).name,' Line:',num2str(err.stack(i).line)];
fprintf(fid,'%s\n',str);
end
subject = [];
content = [];
TargetAddress = '516667408@qq.com';
Attachments = 'Dlog.txt';
MatlabSentMail(subject, content, TargetAddress, Attachments);
end
else
load StockList;
end
%% 获取指数代码列表
run = 1;
if 1 == run
[IndexList] = GetIndexList_Web;
IndexCodeDouble = cell2mat( IndexList(:,3) );
save('IndexList','IndexList');
else
load IndexList;
end
%% SaveStockInfo 获取股票基本信息以及所属行业板块(证监会行业分类)和所属概念板块(新浪财经定义)
run = 0;
if 1 == run
[SaveLog,ProbList,NewList] = SaveStockInfo(StockList);
end
%% SaveStockNotice 获取个股公司公告信息,并保存文件至本地
run = 0;
if 1 == run
[NoticeFileListCell,SaveLog,ProbList,NewList] = SaveStockNotice(StockList);
end
%% SaveStockInvestorRelationsInfo 获取个股投资者关系信息,并保存文件至本地
run = 0;
if 1 == run
[IRInfoFileListCell,SaveLog,ProbList,NewList] = SaveStockInvestorRelationsInfo(StockList);
end
%% SaveIndexTSDay 保存指数数据
run = 1;
if 1 == run
[SaveLog,ProbList,NewList] = SaveIndexTSDay(IndexList);
end
%% 股票数据更新-除权除息数据-无并行操作
run = 1;
if 1 == run
try
AdjFlag = 0;
XRDFlag = 0;
[SaveLog,ProbList,NewList] = SaveStockTSDay(StockList,AdjFlag,XRDFlag);
if ~isempty(ProbList)
[SaveLog,ProbList,NewList] = SaveStockTSDay(ProbList,AdjFlag,XRDFlag);
end
str = ['日期时间:',datestr(now),' 股票数据更新-除权除息数据'];
fprintf(fid,'%s\n',str);
catch err
str = ['日期时间:',datestr(now),' 股票数据更新-除权除息数据失败:',err.message];
fprintf(fid,'%s\n',str);
for i = 1:size(err.stack,1)
str = ['FunName:',err.stack(i).name,' Line:',num2str(err.stack(i).line)];
fprintf(fid,'%s\n',str);
end
subject = [];
content = [];
TargetAddress = '516667408@qq.com';
Attachments = 'Dlog.txt';
MatlabSentMail(subject, content, TargetAddress, Attachments);
end
end
%% 股票数据更新-除权除息数据-并行操作 spmd Test
run = 0;
if 1 == run
WorkNum = 3;
if isempty(gcp('nocreate'))
Pobj = parpool( WorkNum );
Pobj.NumWorkers
end
Pobj = gcp('nocreate');
Pobj.NumWorkers
% delete(Pobj);
% % 30
Sind = 1;
StockList = StockList(Sind:end,:);
SList = cell(WorkNum, 1);
Num = floor( size(StockList,1)/WorkNum );
for i = 1:WorkNum
if i == WorkNum
Lind = 1+Num*(i-1);
SList{i} = StockList(Lind:end,:);
else
Lind = 1+Num*(i-1);
Rind = Lind+Num-1;
SList{i} = StockList(Lind:Rind,:);
end
end
spmd
AdjFlag = 0;
XRDFlag = 0;
[SaveLog,ProbList,NewList] = SaveStockTSDay(SList{labindex},AdjFlag,XRDFlag);
str = ['日期时间:',datestr(now),' 股票数据更新-除权除息数据-并行操作'];
fprintf(fid,'%s\n',str);
end
end
%% 获取交易明细数据Tick-无并行操作
run = 0;
if 1 == run
try
[SaveLog,ProbList,NewList] = SaveStockTick(StockList);
if ~isempty(ProbList)
PList = ProbList;
CheckFlag = 1;
[SaveLog,ProbList,NewList] = SaveStockTick(StockList,[],PList,CheckFlag);
end
str = ['日期时间:',datestr(now),' 获取股票交易明细数据结束'];
fprintf(fid,'%s\n',str);
catch err
str = ['日期时间:',datestr(now),' 获取股票交易明细数据失败:',err.message];
fprintf(fid,'%s\n',str);
for i = 1:size(err.stack,1)
str = ['FunName:',err.stack(i).name,' Line:',num2str(err.stack(i).line)];
fprintf(fid,'%s\n',str);
end
subject = [];
content = [];
TargetAddress = '516667408@qq.com';
Attachments = 'Dlog.txt';
MatlabSentMail(subject, content, TargetAddress, Attachments);
end
end
%% 获取交易明细数据Tick-并行操作 spmd Test
run = 0;
if 1 == run
WorkNum = 3;
if isempty(gcp('nocreate'))
Pobj = parpool( WorkNum );
Pobj.NumWorkers
end
Pobj = gcp('nocreate');
Pobj.NumWorkers
% delete(Pobj);
% % 30
Sind = 1;
StockList = StockList(Sind:end,:);
SList = cell(WorkNum, 1);
Num = floor( size(StockList,1)/WorkNum );
for i = 1:WorkNum
if i == WorkNum
Lind = 1+Num*(i-1);
SList{i} = StockList(Lind:end,:);
else
Lind = 1+Num*(i-1);
Rind = Lind+Num-1;
SList{i} = StockList(Lind:Rind,:);
end
end
spmd
[SaveLog,ProbList,NewList] = SaveStockTick(SList{labindex});
str = ['日期时间:',datestr(now),' 获取股票交易明细数据结束'];
fprintf(fid,'%s\n',str);
end
end
%% 股票数据更新-前复权
run = 0;
if 1 == run
try
AdjFlag = 1;
XRDFlag = 0;
[SaveLog,ProbList,NewList] = SaveStockTSDay(StockList,AdjFlag,XRDFlag);
str = ['日期时间:',datestr(now),' 股票数据更新-前复权'];
fprintf(fid,'%s\n',str);
catch err
str = ['日期时间:',datestr(now),' 股票数据更新-前复权失败:',err.message];
fprintf(fid,'%s\n',str);
for i = 1:size(err.stack,1)
str = ['FunName:',err.stack(i).name,' Line:',num2str(err.stack(i).line)];
fprintf(fid,'%s\n',str);
end
subject = [];
content = [];
TargetAddress = '516667408@qq.com';
Attachments = 'Dlog.txt';
MatlabSentMail(subject, content, TargetAddress, Attachments);
end
end
%% 股票数据更新-后复权
run = 0;
if 1 == run
try
AdjFlag = 2;
XRDFlag = 0;
[SaveLog,ProbList,NewList] = SaveStockTSDay(StockList,AdjFlag,XRDFlag);
str = ['日期时间:',datestr(now),' 股票数据更新-后复权'];
fprintf(fid,'%s\n',str);
catch err
str = ['日期时间:',datestr(now),' 股票数据更新-后复权失败:',err.message];
fprintf(fid,'%s\n',str);
for i = 1:size(err.stack,1)
str = ['FunName:',err.stack(i).name,' Line:',num2str(err.stack(i).line)];
fprintf(fid,'%s\n',str);
end
subject = [];
content = [];
TargetAddress = '516667408@qq.com';
Attachments = 'Dlog.txt';
MatlabSentMail(subject, content, TargetAddress, Attachments);
end
end
%% 除权除息信息
run = 0;
if 1 == run
try
AdjFlag = 0;
XRDFlag = 1;
[SaveLog,ProbList,NewList] = SaveStockTSDay(StockList,AdjFlag,XRDFlag);
if ~isempty(ProbList)
[SaveLog,ProbList,NewList] = SaveStockTSDay(ProbList,AdjFlag,XRDFlag);
end
str = ['日期时间:',datestr(now),' 更新除权除息信息'];
fprintf(fid,'%s\n',str);
catch err
str = ['日期时间:',datestr(now),' 更新除权除息信息失败:',err.message];
fprintf(fid,'%s\n',str);
for i = 1:size(err.stack,1)
str = ['FunName:',err.stack(i).name,' Line:',num2str(err.stack(i).line)];
fprintf(fid,'%s\n',str);
end
subject = [];
content = [];
TargetAddress = '516667408@qq.com';
Attachments = 'Dlog.txt';
MatlabSentMail(subject, content, TargetAddress, Attachments);
end
end
%% 财务指标
run = 0;
if 1 == run
try
Opt = 0;
[SaveLog,ProbList,NewList] = SaveStockFD(StockList,Opt);
if ~isempty(ProbList)
[SaveLog,ProbList,NewList] = SaveStockFD(ProbList,Opt);
end
str = ['日期时间:',datestr(now),' 更新财务指标'];
fprintf(fid,'%s\n',str);
catch err
str = ['日期时间:',datestr(now),' 更新财务指标失败:',err.message];
fprintf(fid,'%s\n',str);
for i = 1:size(err.stack,1)
str = ['FunName:',err.stack(i).name,' Line:',num2str(err.stack(i).line)];
fprintf(fid,'%s\n',str);
end
subject = [];
content = [];
TargetAddress = '516667408@qq.com';
Attachments = 'Dlog.txt';
MatlabSentMail(subject, content, TargetAddress, Attachments);
end
end
%% 3张表
run = 0;
if 1 == run
try
Opt = 1;
[SaveLog,ProbList,NewList] = SaveStockFD(StockList,Opt);
if ~isempty(ProbList)
[SaveLog,ProbList,NewList] = SaveStockFD(ProbList,Opt);
end
str = ['日期时间:',datestr(now),' 更新3张表'];
fprintf(fid,'%s\n',str);
catch err
str = ['日期时间:',datestr(now),' 更新3张表失败:',err.message];
fprintf(fid,'%s\n',str);
for i = 1:size(err.stack,1)
str = ['FunName:',err.stack(i).name,' Line:',num2str(err.stack(i).line)];
fprintf(fid,'%s\n',str);
end
subject = [];
content = [];
TargetAddress = '516667408@qq.com';
Attachments = 'Dlog.txt';
MatlabSentMail(subject, content, TargetAddress, Attachments);
end
end
%% 关闭打开的文件
fclose('all');
%% Exist
% exist;
%% Record Time
toc;
displayEndOfDemoMessage(mfilename);