當前位置: 首頁>>代碼示例>>Python>>正文


Python yahoo_finance.Share方法代碼示例

本文整理匯總了Python中yahoo_finance.Share方法的典型用法代碼示例。如果您正苦於以下問題:Python yahoo_finance.Share方法的具體用法?Python yahoo_finance.Share怎麽用?Python yahoo_finance.Share使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在yahoo_finance的用法示例。


在下文中一共展示了yahoo_finance.Share方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: getStockData

# 需要導入模塊: import yahoo_finance [as 別名]
# 或者: from yahoo_finance import Share [as 別名]
def getStockData(theTicker, startDate):
    stock = Share(theTicker)
    print("Getting Data for ... " + theTicker)
    now = datetime.now()
    DateNow = str(now.year) + "-" + str(now.month) + "-" + str(now.day)
    data = stock.get_historical(startDate, DateNow)
    stockData = []
    for d in data:
        tmp = []
        volume = int(d['Volume'])
        adjclose = float(d['Adj_Close'])
        high = float(d['High'])
        low = float(d['Low'])
        close = float(d['Close'])
        date = d['Date']
        open = float(d['Open'])
        tmp.append(date)
        tmp.append(open)
        tmp.append(high)
        tmp.append(low)
        tmp.append(close)
        tmp.append(adjclose)
        tmp.append(volume)
        stockData.append(tmp)
    return stockData 
開發者ID:Vaibhav,項目名稱:Stock-Analysis,代碼行數:27,代碼來源:stock_scraper.py

示例2: stock_Prices

# 需要導入模塊: import yahoo_finance [as 別名]
# 或者: from yahoo_finance import Share [as 別名]
def stock_Prices():
    # exit if the output already existed
    # if os.path.isfile('./input/stockPrices.json'):
    #     sys.exit("Prices data already existed!")

    priceSet = {}
    fin = open('./input/tickerList.csv')
    for num, line in enumerate(fin):
        line = line.strip().split(',')
        ticker, name, exchange, MarketCap = line
        if 1:
            print(num, ticker)
            yahoo = Share(ticker)
            time.sleep(np.random.poisson(3))
            prices = yahoo.get_historical('2005-01-01', '2020-01-01')
            priceDt = {}
            for i in range(len(prices)):
                date = ''.join(prices[i]['Date'].split('-'))
                priceDt[date] = round(log(float(prices[i]['Close']) / float(prices[i]['Open'])), 6)
            priceSet[ticker] = priceDt
        #except:
            #continue

    with open('./input/stockPrices.json', 'w') as outfile:
        json.dump(priceSet, outfile, indent=4) 
開發者ID:WayneDW,項目名稱:Sentiment-Analysis-in-Event-Driven-Stock-Price-Movement-Prediction,代碼行數:27,代碼來源:crawler_stockPrices.py

示例3: get_stock_info_and_historical_data

# 需要導入模塊: import yahoo_finance [as 別名]
# 或者: from yahoo_finance import Share [as 別名]
def get_stock_info_and_historical_data(symbol):
    """Retrieve stock info and historical data for `symbol`

    Leverages yahoo-finance for Python
    https://github.com/lukaszbanasiak/yahoo-finance
    """
    share = yahoo_finance.Share(symbol)
    info = share.get_info()
    start_date = info['start']
    end_date = info['end']
    historical = share.get_historical(start_date, end_date)
    data = {
        'info' : info,
        'historical' : historical,
    }
    return data 
開發者ID:hacktoolkit,項目名稱:django-htk,代碼行數:18,代碼來源:utils.py

示例4: get_quote

# 需要導入模塊: import yahoo_finance [as 別名]
# 或者: from yahoo_finance import Share [as 別名]
def get_quote(self, session, stock, data=None):
        update_time = pd.Timestamp(datetime.datetime.now()) - pd.DateOffset(minutes=15)
        if stock is None or not hasattr(stock, 'quotes') or not hasattr(stock, 'symbol'):
            return None
        seconds = self.seconds_until_market_open()
        quote = self.get_quote_latest(session, stock)

        market_closed = (seconds > 15*60)
        if quote is None \
                or (not market_closed and quote.date_inserted <= update_time)\
                or (market_closed and quote.date_inserted.minute < 30 and quote.date_inserted.hour == 13):
            if data is None:
                data = get_stock_data(Share(stock.symbol), field_map)
            quote = Quote(**{k: v
                             for k, v in data.items()
                             if k in quote_keys})
            logger.info("UPDATED QUOTE: {}".format(quote))
            stock.quotes.append(quote)

        else:
            logging.info("EXISTING QUOTE: {}".format(quote))

        return quote 
開發者ID:zbarge,項目名稱:stocklook,代碼行數:25,代碼來源:database.py

示例5: getReturns

# 需要導入模塊: import yahoo_finance [as 別名]
# 或者: from yahoo_finance import Share [as 別名]
def getReturns(stocks = 'MSFT,AAPL,NFLX,JPM,UVXY,RSX,TBT', period_days = 100, end = '2016-12-09'):
    stocks = stocks.split(",")
    index = 'SPY'
    stocks.append(index)
    if end is None:
        end = datetime.today().strftime("%Y-%m-%d")
    start = (datetime.today() - timedelta(period_days)).strftime("%Y-%m-%d")
        
    i = 0
    w= pd.DataFrame()
    t = []
    for s in stocks:
        z = Share(s)
        px = pd.DataFrame(z.get_historical(start,end))[['Close','Date']]
        px['Close']=px['Close'].astype(float)
        px.index = px['Date']
        del px['Date']
        px.columns = [s]
        t.append(px)
    w = pd.concat(t,axis=1, join='inner')
    w = w.sort_index().pct_change()  #returns => w.cov() covariance matrix of returns
    #calculate betas
    betas = []
    for s in stocks:
        if s != index:
            col = np.column_stack((w[s],w[index]))
            b = np.cov(col)/np.var(w[index])
            betas.append(b)  
    stocks.remove(index)
    del w[index]
    returns = w
    return returns,stocks,np.round(betas,4) 
開發者ID:wolfws,項目名稱:sandbox-portfolio-optimization-cvxpy,代碼行數:34,代碼來源:cvxpy_portfolio.py

示例6: get_stock_price

# 需要導入模塊: import yahoo_finance [as 別名]
# 或者: from yahoo_finance import Share [as 別名]
def get_stock_price(symbol):
    """Retrieve the latest price for `symbol` representing stock
    """
    share = yahoo_finance.Share(symbol)
    price = share.get_price()
    return price 
開發者ID:hacktoolkit,項目名稱:django-htk,代碼行數:8,代碼來源:utils.py

示例7: _add_stock

# 需要導入模塊: import yahoo_finance [as 別名]
# 或者: from yahoo_finance import Share [as 別名]
def _add_stock(self, session, name, data=None):
        if data is None:
            try:
                data = get_stock_data(Share(name), field_map)
            except:
                return None

        stock = Stock(**{k: v for k, v in data.items() if k in stock_keys})
        try:
            session.add(stock)
        except:
            pass
        return data 
開發者ID:zbarge,項目名稱:stocklook,代碼行數:15,代碼來源:database.py

示例8: update_historical

# 需要導入模塊: import yahoo_finance [as 別名]
# 或者: from yahoo_finance import Share [as 別名]
def update_historical(self, session, stock, start_date, end_date):
        share = Share(stock.symbol)
        try:
            data = get_stock_data_historical(share, start_date, end_date)
        except YQLResponseMalformedError as e:
            logger.error(e)
            return None
        matching_quotes = session.query(Quote).filter(and_(Quote.stock_id == stock.id,
                                                           Quote.date_last_traded >= pd.Timestamp(start_date),
                                                           Quote.date_last_traded <= pd.Timestamp(end_date)))\
                                 .order_by(Quote.date_inserted.asc())
        dates = [pd.Timestamp(q.date_last_traded).date() for q in matching_quotes.all()
                 if pd.Timestamp(q.date_last_traded).hour > 13]

        quotes = []
        for record in data:
            try:
                if record[Quote.date_last_traded.name].date() not in dates:
                    quote = Quote(**{k: v
                                     for k, v in record.items()
                                     if k in quote_keys})
                    quote.symbol_name = stock.symbol_name
                    quote.stock_exchange = stock.stock_exchange
                    quote.trade_currency = stock.trade_currency
                    quotes.append(quote)
                    stock.quotes.append(quote)
            except (KeyError, ValueError) as e:
                logger.error("Error parsing historical quote - {} - {}".format(e, record))
        [session.add(q) for q in quotes]
        return quotes 
開發者ID:zbarge,項目名稱:stocklook,代碼行數:32,代碼來源:database.py

示例9: generate_stock_updates

# 需要導入模塊: import yahoo_finance [as 別名]
# 或者: from yahoo_finance import Share [as 別名]
def generate_stock_updates(file_path=None):
    if file_path is None:
        file_path = 'C:/Users/Zeke/Google Drive/Documents/Financial/td_ameritrade/'\
                    'Watchlist_Uranium_2017-02-18.xlsx'
    df = read_excel(file_path)

    new_data = []
    for i in range(df.index.size):
        row = df.iloc[i]
        share = Share(row['Symbol'])
        new_data.append(share.__dict__.get('data_set', {}))

    path_out = os.path.splitext(file_path)[0] + '-updated.csv'
    new_df = DataFrame(new_data, index=range(len(new_data)))
    new_df.to_csv(path_out) 
開發者ID:zbarge,項目名稱:stocklook,代碼行數:17,代碼來源:parsing.py

示例10: get_quotes

# 需要導入模塊: import yahoo_finance [as 別名]
# 或者: from yahoo_finance import Share [as 別名]
def get_quotes(self):
        self.debug("getting quotes")
        try:
            quotes = {}
            for i in self.assets:
                yahoo = Share(i)
                quotes[i] = {
                    "source": "yahoo",
                    "last": float(yahoo.get_price())
                }
            return quotes
        except OSError:
            self.error("Network Error") 
開發者ID:joequant,項目名稱:algobroker,代碼行數:15,代碼來源:ticker_yahoo.py


注:本文中的yahoo_finance.Share方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。