可以自动将股票添加到板块列表中,而不是逐个添加吗?

huangapple go评论59阅读模式
英文:

Is it possible to automate the adding of tickers to sector lists rather than adding individual ones?

问题

可以将代码部分提取如下:

import yfinance as yf

y = int(input("number of tickers:"))

def info(x, industry):
    comp = yf.Ticker(x)
    print(comp.history(period="1d").head())
    print(comp.info['forwardPE'])
    print(comp.info['trailingPE'])
    print(comp.info['beta'])

for a in range(y):
    info(x=input("Enter ticker: "))

请注意,这段代码中包含了一些针对股票数据的操作,但您想要的翻译似乎是关于如何自动将股票添加到行业列表中的问题。如果需要关于这个问题的翻译,请提供更多上下文或明确的要求。

英文:

Is it possible to automate the adding of tickers to sector lists rather than adding individual ones by iterating through the database of available tickers listed in the USA? I'm not sure how i would access the database rather than a specific ticker, so that i can begin iterating through which i believe should be simpler. Also, if anyone has a list of commands that can be used within yfinance, that would be great. I have had mixed success with those found online.

import yfinance as yf

y = int(input("number of tickers:"))

def info(x, industry):
    comp = yf.Ticker(x)
    print(comp.history(period="1d").head())
    print(comp.info['forwardPE'])
    print(comp.info['trailingPE'])
    print(comp.info['beta'])

for a in range(y):
    info(x=input("Enter ticker: "))

i have used this to get some basic data from a couple of companies at a time but i would like to be able to add a section of code which can go through the yahoo finance database of available tickers listed in the USA and add relevant companies to an sector-specific list - rather than adding them individually - such as "energy" or "basic materials".

答案1

得分: 0

尝试定义sectors字典中各个部门及其相应的行业。get_tickers_by_sector函数以部门作为输入,根据来自yfinance的部门和行业信息,检索属于该部门的所有在美国上市的股票代码。

您可以根据需要扩展sectors字典,添加更多部门及其相应的行业。

import yfinance as yf
import pandas as pd

sectors = {
    'energy': ['XOM', 'CVX', 'BP'],
    'basic_materials': ['DD', 'LIN', 'FCX'],
    'technology': ['AAPL', 'MSFT', 'GOOGL'],
    'healthcare': ['JNJ', 'PFE', 'UNH'],
    'finance': ['JPM', 'BAC', 'GS']
    # 根据需要添加更多部门及其相应的股票代码
}

def get_historical_data_with_sector(sectors, start_date, end_date):
    data = pd.DataFrame()
    for sector, tickers in sectors.items():
        sector_data = yf.download(tickers, start=start_date, end=end_date)
        sector_data['Sector'] = sector
        data = pd.concat([data, sector_data])
    return data

# 示例用法
start_date = '2022-01-01'
end_date = '2022-12-31'

historical_data = get_historical_data_with_sector(sectors, start_date, end_date)
print(historical_data)

查看更多详细信息,请参阅官方文档:https://pypi.org/project/yfinance/

英文:

Try to define the sectors and their corresponding industries in the sectors dictionary. The get_tickers_by_sector function takes a sector as input and retrieves all tickers listed in the USA that belong to that sector based on the sector and industry information from yfinance.

You can extend the sectors dictionary with more sectors and their corresponding industries as needed.

import yfinance as yf
import pandas as pd

sectors = {
    'energy': ['XOM', 'CVX', 'BP'],
    'basic_materials': ['DD', 'LIN', 'FCX'],
    'technology': ['AAPL', 'MSFT', 'GOOGL'],
    'healthcare': ['JNJ', 'PFE', 'UNH'],
    'finance': ['JPM', 'BAC', 'GS']
    # Add more sectors and their corresponding ticker symbols as needed
}

def get_historical_data_with_sector(sectors, start_date, end_date):
    data = pd.DataFrame()
    for sector, tickers in sectors.items():
        sector_data = yf.download(tickers, start=start_date, end=end_date)
        sector_data['Sector'] = sector
        data = pd.concat([data, sector_data])
    return data

# Example usage
start_date = '2022-01-01'
end_date = '2022-12-31'

historical_data = get_historical_data_with_sector(sectors, start_date, end_date)
print(historical_data)

Check the official documentation for more details: https://pypi.org/project/yfinance/

huangapple
  • 本文由 发表于 2023年7月3日 05:29:12
  • 转载请务必保留本文链接:https://go.coder-hub.com/76600872.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定