2017-09-05 25 views
0
import pandas_datareader.data as web 
import pandas, xlrd 
from datetime import datetime, timedelta 
import csv 

end = datetime.now() # 마지막 날을 오늘로 설정 
start = end - timedelta(days=250) # 시작 날을 오늘로 부터 250일 전으로 설정 

stock_code = pandas.read_excel('/home/ubuntu/trading/Book1.xlsx', dtype=str, encoding="CP949").as_matrix() 

#250일 모멘텀 계산 
for st in stock_code: 
    eventcode = st[0] 
    try: 
     df = web.DataReader("krx:%s" % eventcode, "google", start, end) #코스피이면 구글에서 데이터 받음 
    except: 
     df = web.DataReader("%s.KQ" % eventcode, "yahoo", start, end) #코스닥이면 야후에서 데이터 받음 
     try: 
      df=web.DataReader("%s.KQ" % eventcode, "yahoo", start, end) #코스닥이면 야후에서 데이터 받음 
     except: 
      df = web.DataReader("%s.KQ" % eventcode, "yahoo", start, end) # 코스닥이면 야후에서 데이터 받음 
    close = df['Close'] 
    num = len(close) 

    sum = 0 
    for x in range(0, num - 1): 
     if close[x + 1]/close[x] == 1: #당일 종가가 전날 종가와 같으면 0 추가 
      sum = sum + 0 
     elif close[x + 1]/close[x] > 1: #당일 종가가 전날 종가 보다 높으면 1 추가 
      sum = sum + 1 
     else: #당일 종가가 전날 종가가 낮으면 -1. 
      sum = sum - 1 
    print(sum) #최종값 

親愛なる皆さん。 私はgoogleとyahooから株データを取得したいと思います。 yahooからデータを取得できないことがあります。数秒後にもう一度試してみると、私はデータを得ることができます。Pythonで例外処理を繰り返す方法

ですので試してみてください。 yahooからデータを取得できない場合。私は再び3回試してみたい。 私はtryを入れて、exceptを除いて。 でも動作しません。

私はそれをどのように修正するのですか?

これは、エラー

pandas_datareader._utils.RemoteDataError: Unable to read URL: https://query1.finance.yahoo.com/v7/finance/download/003100.KQ?period1=1483019682&period2=1504655999&crumb=Vxp9S4A%5Cu002FjwQ&interval=1d&events=history 
+0

'time.sleep()'を使って再試行の間に遅延を導入しようとします。 – gipsy

答えて

0

あなたがスリープロジックで行くことができますし、あなたにも、リトライの数を制限することができている

DF =なし

DFがいる間なし:

try: 

    df = web.DataReader("krx:%s" % eventcode, "google", start, end) 

except: 

sleep(1000) 
df = None 
関連する問題