编写一个Python脚本,可以读取一个csv文件,并使用该输入从finviz.com上进行数据爬取,然后将数据导出到一个csv文件中。
创始人
2024-12-07 07:01:22
0

以下是一个Python脚本的示例,可以读取一个csv文件,并使用该输入从finviz.com上进行数据爬取,然后将数据导出到一个csv文件中。请确保安装了所需的库,如pandas、beautifulsoup和requests。

import pandas as pd
import requests
from bs4 import BeautifulSoup

# 从csv文件中读取输入数据
input_data = pd.read_csv('input.csv')

# 创建一个空的DataFrame来存储结果数据
output_data = pd.DataFrame(columns=['Symbol', 'Company', 'Sector', 'Industry'])

# 遍历输入数据
for index, row in input_data.iterrows():
    symbol = row['Symbol']
    url = f'https://finviz.com/quote.ashx?t={symbol}'
    
    # 发送GET请求并解析HTML响应
    response = requests.get(url)
    soup = BeautifulSoup(response.text, 'html.parser')
    
    # 从解析后的HTML中提取所需的数据
    company = soup.find('table', {'class': 'fullview-title'}).findAll('tr')[1].findAll('td')[0].text
    sector = soup.find('a', text='Sector').findNext('a').text
    industry = soup.find('a', text='Industry').findNext('a').text
    
    # 将提取的数据添加到结果DataFrame中
    output_data = output_data.append({'Symbol': symbol, 'Company': company, 'Sector': sector, 'Industry': industry}, ignore_index=True)

# 将结果DataFrame保存为csv文件
output_data.to_csv('output.csv', index=False)

请将上述代码保存为一个Python脚本(例如script.py),并确保在同一目录下有一个名为input.csv的csv文件。然后运行脚本,它将从input.csv读取输入数据,并将爬取的数据保存为output.csv。请根据需要修改脚本中的csv文件名和列名。

相关内容

热门资讯

Android Recycle... 要在Android RecyclerView中实现滑动卡片效果,可以按照以下步骤进行操作:首先,在项...
安装apache-beam==... 出现此错误可能是因为用户的Python版本太低,而apache-beam==2.34.0需要更高的P...
Android - 无法确定任... 这个错误通常发生在Android项目中,表示编译Debug版本的Java代码时出现了依赖关系问题。下...
Android - NDK 预... 在Android NDK的构建过程中,LOCAL_SRC_FILES只能包含一个项目。如果需要在ND...
Akka生成Actor问题 在Akka框架中,可以使用ActorSystem对象生成Actor。但是,当我们在Actor类中尝试...
Agora-RTC-React... 出现这个错误原因是因为在 React 组件中使用,import AgoraRTC from “ago...
Alertmanager在pr... 首先,在Prometheus配置文件中,确保Alertmanager URL已正确配置。例如:ale...
Aksnginxdomainb... 在AKS集群中,可以使用Nginx代理服务器实现根据域名进行路由。以下是具体步骤:部署Nginx i...
AddSingleton在.N... 在C#中创建Singleton对象通常是通过私有构造函数和静态属性来实现,例如:public cla...
Alertmanager中的基... Alertmanager中可以使用repeat_interval选项指定在一个告警重复发送前必须等待...