python代碼計算期權期貨
A. 怎麼用python計算股票
作為一個python新手,在學習中遇到很多問題,要善於運用各種方法。今天,在學習中,碰到了如何通過收盤價計算股票的漲跌幅。
第一種:
讀取數據並建立函數:
import numpy as np
import matplotlib.pyplot as plt
from scipy.interpolate import spline
from pylab import *
import pandas as pd
from pandas import Series
a=pd.read_csv('d:///1.csv',sep=',')#文件位置
t=a['close']
def f(t):
s=[]
for i in range(1,len(t)):
if i==1:
continue
else:
s.append((t[i]-t[i-1])/t[i]*100)
print s
plot(s)
plt.show()
f(t)
第二種:
利用pandas裡面的方法:
import pandas as pd
a=pd.read_csv('d:///1.csv')
rets = a['close'].pct_change() * 100
print rets
第三種:
close=a['close']
rets=close/close.shift(1)-1
print rets
總結:python是一種非常好的編程語言,一般而言,我們可以運用構建相關函數來實現自己的思想,但是,眾所周知,python中裡面的有很多科學計算包,裡面有很多方法可以快速解決計算的需要,如上面提到的pandas中的pct_change()。因此在平時的使用中應當學會尋找更好的方法,提高運算速度。
B. 怎樣用 Python 寫一個股票自動交易的程序
方法一
前期的數據抓取和分析可能python都寫好了,所以差這交易指令介面最後一步。對於股票的散戶,正規的法子是華寶,國信,興業這樣願意給介面的券商,但貌似開戶費很高才給這權利,而且只有lts,ctp這樣的c++介面,沒python版就需要你自己封裝。
方法二
是wind這樣的軟體也有直接的介面,支持部分券商,但也貴,幾萬一年是要的。
方法三
滑鼠鍵盤模擬法,很復雜的,就是模擬鍵盤滑鼠去操作一些軟體,比如券商版交易軟體和大智慧之類的。
方法四
就是找到這些軟體的關於交易指令的底層代碼並更改,不過T+1的規則下,預測准確率的重要性高於交易的及時性,花功夫做數據分析就好,交易就人工完成吧
C. 怎麼編寫一段python3的代碼,點擊Calculate就可以得出結果呢
defjs(code):
try:
exec('re='+code)
returnre
exceptException,e:
printe
printjs('3*4')
printjs('3+4')
printjs('3-4')
printjs('3/4')
printjs('3+4*3')
D. 如何用python計算隱含波動率
隱含波動率是 期權價格已知後反推出來的,現實中的期權價格(F)和理論是有偏差的,所以交易中,期權價格F是競價的結果,而F對應的波動率則是隱含的,可求出對應的波動率(比如迭代法),即隱含波動率。
B-S公式由,S,Sigma,T,K,R可算出的是理論的期權價格,其反推波動率當然還是Sigma。
E. Python是否有期權定價包
暫時沒有,不過如果是單用BS-option pricing的公式,其實很好編,基本上都是線性的函數。
F. 如何用python計算某支股票持有90天的收益率
defget(self,get,money):
print「ATM:」
print「yourmoneyis+「,self.get,」%aday
self.today=self.money*(self.get/100)+self.money
print「nowyouhave」,self.today
self.tomorrow=self.today*(self.get/100)+self.today
print「tomorrowyouwellhave」,self.tomorrow
get(50,10000)
這個代碼會給你1天後和2天後的余額,如果要顯示九十天,還請您自己打完
G. 只為了自己遍自己用的炒期貨軟體,學Python還是C#
這兩個都沒用,期貨和股票之類的需要藉助於第三方平台,象TradeBlazer,你所做的編程和開發也是需要用它提供的語言來進行,與C#什麼的沒有任何關系。
H. python可以讀取到國內期貨歷史tick數據嗎
歷史tick數據是需要花錢買的。和用什麼軟體沒關系。
I. 寫一個Python程序計算題。。
#python3
P,n,r=10000,12,8/100
t=int(input('howmanyyears:'))
A=P*(1+r/n)**(n*t)
print('{}年後的金額是:¥{:.2f}'.format(t,A))
運行結果:
how many years:6
6 年後的金額是:¥16135.02
J. 誰有最小二乘蒙特卡洛方法的美式期權定價python程序代碼
function [c,p]=ucoption(S,X,sigma,r,T,M) sig2=sigma^2; srT=sqrt(T); srTa=sigma*srT; c=0; p=0; for i=1:M ST=S*exp((r-0.5*sig2)*T+srTa*randn); c=c+max(ST-X,0); p=p+max(X-ST,0); end c=c/M; p=p/M; [Call,Put] = blsprice(S, X, r, T, ...