- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
在某人的博客上,我发现了一些我想用python修改的代码。
但我不知道 Matlab 语法或代码或有 MATLAB 来测试......谁能帮忙用python重写一下,少评论。
我感兴趣的雅虎符号是 MSFT、IBM 和 SPY。 CSV 输出效果很好。
function DataOut = Get_Yahoo_Options_Data(symbolid)
%Get_Yahoo_Options_Data get Option Chain Data from Yahoo
% Get Options Chain Data from Yahoo
% DataOut = Get_Yahoo_Options_Data(symbol)
% Inputs: Symbol name as a character String
% Output: A structure with the following fields
% data : A 1xN cell where N is the number of Expiries available
% ExpDates : A 1xN cell array of Expiry Dates
% Calls : A 1xN cell array of Call Option data for each expiry
% Puts : A 1xN cell array of Put Option data
% CPHeaders : Headers for the calls and puts option data
% Headers: Headers for the data
% FullOptionData : A combined cell array of DataOut.data
% Last : Last Price
% Example:
% DataOut = Get_Yahoo_Options_Data('LVS');
% (c)tradingwithmatlab.blogspot.com
DataOut = struct;
% Construct and read the URL from Yahoo Finance Website
urlText = urlread(['http://finance.yahoo.com/q/os?s=' symbolid]);
% Try getting the Table Data from URL Text
TableData = getTableData();
% If Empty return
if(isempty(TableData))
return
else
DataOut.data{1} = TableData;
end
% Get the Expiry Date for later use
DataOut.ExpDates{1} = Get_Exp_Dates();
% Get Expiry Dates that are listed in the website to construct separate
% URLS for each month
NextExpiryURL = Get_Next_Expiry_URL();
if(isempty(NextExpiryURL))
return
end
% Now read Option Tables of each Expiry month
for ik = 1:length(NextExpiryURL)
urlText = urlread(NextExpiryURL{ik});
DataOut.ExpDates{ik+1} = Get_Exp_Dates();
DataOut.data{ik+1} = getTableData();
end
% Clean Up
% Convert the strings into numbers
f = @(x)[x(:,1) num2cell(str2double(x(:,[2:8]))) x(:,9) num2cell(str2double(x(:,10:end)))];
DataOut.data = cellfun(f,DataOut.data,'uni',false);
% Separate the data into Calls, Puts, Headers
DataOut.Calls = cellfun(@(x) x(:,[1 8 2:7]),DataOut.data,'uni',false);
DataOut.Puts = cellfun(@(x) x(:,[9 8 10:end]),DataOut.data,'uni',false);
DataOut.CPHeaders = {'Symbol','Strike','Last','Change','Bid','Ask','Volume','Open Int'};
DataOut.Headers = {'Symbol','Last','Change','Bid','Ask','Volume','Open Int','Strike',...
'Symbol','Last','Change','Bid','Ask','Volume','Open Int'};
DataOut.FullOptionData = [DataOut.Headers ; cat(1,DataOut.data{:})];
% Get the Last Price
DataOut.Last = str2num(urlread(['http://download.finance.yahoo.com/d/quotes.csv?s=' symbolid '&f=l1&e=.csv']));
%% Get_Next_Expiry_URL
function NextExpiry = Get_Next_Expiry_URL()
% Get the start and end indices and look for a particular text
Start = regexp(urlText,'View By Expiration:','end');
end1 = regexp(urlText,'Return to Stacked View...','start');
Data = urlText(Start:end1);
Data=Data(2:end);
% Trim the data
Data=strtrim(Data);
% Split the data into new lines
newlines = regexp(Data, '[^\n]*', 'match');
expr = '<(\w+).*?>.*?</\1>';
if(isempty(newlines))
NextExpiry = {};
return
end
% Get the matches of particular expression
[tok mat] = regexp(newlines{1}, expr, 'tokens', 'match');
id1= regexp(mat{1},'</b>','start')-1;
month{1} = mat{1}(4:id1);
%Month and Next Expiries
for j = 2:length(mat)-1
id2 = regexp(mat{j},'">','end');
id3 = regexp(mat{j},'</a','start');
if(isempty(id3))
return
end
month{j} = mat{j}(id2+1:id3-1);
id4 = regexp(mat{j},'"','start');
NextExpiry{j-1} = ['http://finance.yahoo.com' mat{j}(id4(1)+1:id4(2)-1)]; %#ok<*AGROW>
NextExpiry{j-1} = regexprep(NextExpiry{j-1},'amp;','');
end
end
%% Get_Exp_Dates
function ExpDates = Get_Exp_Dates()
id1 = regexp(urlText,'Options Expiring','end');
id2 = regexp((urlText(id1+1:id1+51)),'</b>','start');
ExpDates = strtrim(urlText(id1+1:id1+1+id2-2));
ExpDates=datestr(datenum(ExpDates,'dddd, mmmm dd,yyyy'));
end
%% getTableData
function out = getTableData()
Main_Pattern = '.*?</table><table[^>]*>(.*?)</table';
Tables = regexp(urlText, Main_Pattern, 'tokens');
out = {};
if(isempty(Tables))
return
end
try
for TableIdx = 1 : length(Tables)
%Establish a row index
rowind = 0;
% Build cell aray of table data
rows = regexpi(Tables{TableIdx}{:}, '<tr.*?>(.*?)</tr>', 'tokens');
for rowsIdx = 1:numel(rows)
colind = 0;
if (isempty(regexprep(rows{rowsIdx}{1}, '<.*?>', '')))
continue
else
rowind = rowind + 1;
end
headers = regexpi(rows{rowsIdx}{1}, '<th.*?>(.*?)</th>', 'tokens');
if ~isempty(headers)
for headersIdx = 1:numel(headers)
colind = colind + 1;
data = regexprep(headers{headersIdx}{1}, '<.*?>', '');
if (~strcmpi(data,' '))
out{rowind,colind} = strtrim(data);
end
end
continue
end
cols = regexpi(rows{rowsIdx}{1}, '<td.*?>(.*?)</td>', 'tokens');
for colsIdx = 1:numel(cols)
if(rowind==1)
if(isempty(cols{colsIdx}{1}))
continue
else
colind = colind + 1;
end
else
colind = colsIdx;
end
% The following code is required to get the sign
% of the change in Bid ask prices
data = regexprep(cols{colsIdx}{1}, ' ', ' ');
down=false;
% If Down is found then it is negative
if(~isempty(regexp(data,'"Down"', 'once')))
down=true;
end
data = regexprep(data, '<.*?>', '');
if(down)
data = ['-' strtrim(data)];
end
if (~isempty(data))
out{rowind,colind} = strtrim(data) ;
end
end % colsIdx
end
end
out = out(3:end,:);
catch %M %#ok<CTCH> This depends on which version of matlab you are using
%M.stack
end
end
end
Get_Yahoo_Options_Data.m http://tradingwithmatlab.blogspot.com/
最佳答案
这是一个 MATLAB 到 Python 的“编译器”:http://ompc.juricap.com/
甚至还有一个在线版本,您可以将代码剪切并粘贴到:http://ompclib.appspot.com/m2py
它转换了您的代码而没有崩溃,但我可以发现转换中的一些问题。然而,这可能是一个很好的起点,您可以手动清理。
关于python - 如何将 MATLAB 文件转换为 PYTHON?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4811136/
我正在处理一组标记为 160 个组的 173k 点。我想通过合并最接近的(到 9 或 10 个组)来减少组/集群的数量。我搜索过 sklearn 或类似的库,但没有成功。 我猜它只是通过 knn 聚类
我有一个扁平数字列表,这些数字逻辑上以 3 为一组,其中每个三元组是 (number, __ignored, flag[0 or 1]),例如: [7,56,1, 8,0,0, 2,0,0, 6,1,
我正在使用 pipenv 来管理我的包。我想编写一个 python 脚本来调用另一个使用不同虚拟环境(VE)的 python 脚本。 如何运行使用 VE1 的 python 脚本 1 并调用另一个 p
假设我有一个文件 script.py 位于 path = "foo/bar/script.py"。我正在寻找一种在 Python 中通过函数 execute_script() 从我的主要 Python
这听起来像是谜语或笑话,但实际上我还没有找到这个问题的答案。 问题到底是什么? 我想运行 2 个脚本。在第一个脚本中,我调用另一个脚本,但我希望它们继续并行,而不是在两个单独的线程中。主要是我不希望第
我有一个带有 python 2.5.5 的软件。我想发送一个命令,该命令将在 python 2.7.5 中启动一个脚本,然后继续执行该脚本。 我试过用 #!python2.7.5 和http://re
我在 python 命令行(使用 python 2.7)中,并尝试运行 Python 脚本。我的操作系统是 Windows 7。我已将我的目录设置为包含我所有脚本的文件夹,使用: os.chdir("
剧透:部分解决(见最后)。 以下是使用 Python 嵌入的代码示例: #include int main(int argc, char** argv) { Py_SetPythonHome
假设我有以下列表,对应于及时的股票价格: prices = [1, 3, 7, 10, 9, 8, 5, 3, 6, 8, 12, 9, 6, 10, 13, 8, 4, 11] 我想确定以下总体上最
所以我试图在选择某个单选按钮时更改此框架的背景。 我的框架位于一个类中,并且单选按钮的功能位于该类之外。 (这样我就可以在所有其他框架上调用它们。) 问题是每当我选择单选按钮时都会出现以下错误: co
我正在尝试将字符串与 python 中的正则表达式进行比较,如下所示, #!/usr/bin/env python3 import re str1 = "Expecting property name
考虑以下原型(prototype) Boost.Python 模块,该模块从单独的 C++ 头文件中引入类“D”。 /* file: a/b.cpp */ BOOST_PYTHON_MODULE(c)
如何编写一个程序来“识别函数调用的行号?” python 检查模块提供了定位行号的选项,但是, def di(): return inspect.currentframe().f_back.f_l
我已经使用 macports 安装了 Python 2.7,并且由于我的 $PATH 变量,这就是我输入 $ python 时得到的变量。然而,virtualenv 默认使用 Python 2.6,除
我只想问如何加快 python 上的 re.search 速度。 我有一个很长的字符串行,长度为 176861(即带有一些符号的字母数字字符),我使用此函数测试了该行以进行研究: def getExe
list1= [u'%app%%General%%Council%', u'%people%', u'%people%%Regional%%Council%%Mandate%', u'%ppp%%Ge
这个问题在这里已经有了答案: Is it Pythonic to use list comprehensions for just side effects? (7 个答案) 关闭 4 个月前。 告
我想用 Python 将两个列表组合成一个列表,方法如下: a = [1,1,1,2,2,2,3,3,3,3] b= ["Sun", "is", "bright", "June","and" ,"Ju
我正在运行带有最新 Boost 发行版 (1.55.0) 的 Mac OS X 10.8.4 (Darwin 12.4.0)。我正在按照说明 here构建包含在我的发行版中的教程 Boost-Pyth
学习 Python,我正在尝试制作一个没有任何第 3 方库的网络抓取工具,这样过程对我来说并没有简化,而且我知道我在做什么。我浏览了一些在线资源,但所有这些都让我对某些事情感到困惑。 html 看起来
我是一名优秀的程序员,十分优秀!