搜索
首页后端开发Python教程网络抓取和分析外语数据

最近我决定做一个快速的网页抓取和数据分析项目。因为我的大脑喜欢想出需要花费大量时间的大想法,所以我决定挑战自己,想出一些可以在几个小时内完成的简单事情。

这是我想到的:

由于我的本科学位最初是外语(法语和西班牙语),我认为网络抓取一些语言相关数据会很有趣。我想使用 BeautifulSoup 库,它可以解析静态 html,但无法处理需要 onclick 事件来显示整个数据集的动态网页(即,如果页面已分页,则单击下一页数据)。

我决定使用最常用语言的维基百科页面。

Web scraping and analysing foreign languages data

我想做以下事情:

  • 获取页面的 html 并输出到 .txt 文件
  • 使用beautiful soup解析html文件并提取表数据
  • 将表格写入 .csv 文件
  • 使用数据分析提出我想回答此数据集的 10 个问题
  • 使用 pandas 和 Jupyter Notebook 回答这些问题

我决定将项目分成这些步骤以分离关注点,但我也想避免通过重新运行脚本来发出多个不必要的请求以从维基百科获取 html。保存 html 文件,然后在单独的脚本中使用它意味着您不需要不断重新请求数据,因为您已经拥有了数据。

项目链接

此项目的 github 存储库的链接是:https://github.com/gabrielrowan/Foreign-Languages-Analysis

获取html

首先,我检索并输出 html。使用 C# 和 C 后,我总是对 Python 代码如此简短和简洁感到新奇?

url = 'https://en.wikipedia.org/wiki/List_of_languages_by_number_of_native_speakers'

response = requests.get(url)
html = response.text

with open("languages_html.txt", "w", encoding="utf-8") as file:
    file.write(html)

解析 html

为了用 Beautiful soup 解析 html 并选择我感兴趣的表,我做了:

with open("languages_html.txt", "r", encoding="utf-8") as file:
    soup = BeautifulSoup(file, 'html.parser')

# get table
top_languages_table = soup.select_one('.wikitable.sortable.static-row-numbers')


然后,我获取了表标题文本来获取 pandas 数据框的列名称:

# get column names
columns = top_languages_table.find_all("th")
column_titles = [column.text.strip() for column in columns]

之后,我创建了数据框,设置列名称,检索每个表行并将每一行写入数据框:

# get table rows
table_data = top_languages_table.find_all("tr")

# define dataframe
df = pd.DataFrame(columns=column_titles)

# get table data
for row in table_data[1:]:
    row_data = row.find_all('td')
    row_data_txt = [row.text.strip() for row in row_data]
    print(row_data_txt)
    df.loc[len(df)] = row_data_txt 


注意 - 不使用 strip() 时,文本中有 n 个不需要的字符。

最后,我将数据帧写入 .csv。

分析数据

事先,我从数据中提出了我想回答的这些问题:

  1. 数据集中所有语言的母语总数是多少?
  2. 有多少种不同类型的语系?
  3. 每个语系的母语总数是多少?
  4. 最常用的 3 个语系是什么?
  5. 创建一个饼图,显示最常用的 3 个语系
  6. 最常见的语系-分支对是什么?
  7. 表中哪些语言属于汉藏语系?
  8. 显示所有罗曼语系和日耳曼语系语言的母语人士的条形图
  9. 前 5 种语言占母语使用者总数的百分比是多少?
  10. 哪个分支的母语使用者最多,哪个分支最少?

结果

虽然我不会通过代码来回答所有这些问题,但我会讨论涉及图表的两个问题。

显示所有罗曼语和日耳曼语母语的条形图

首先,我创建了一个数据框,仅包含分支名称为“Romance”或“Germanic”的行

url = 'https://en.wikipedia.org/wiki/List_of_languages_by_number_of_native_speakers'

response = requests.get(url)
html = response.text

with open("languages_html.txt", "w", encoding="utf-8") as file:
    file.write(html)

然后我指定了图表的 x 轴、y 轴和条形颜色:

with open("languages_html.txt", "r", encoding="utf-8") as file:
    soup = BeautifulSoup(file, 'html.parser')

# get table
top_languages_table = soup.select_one('.wikitable.sortable.static-row-numbers')


这创建了:

Web scraping and analysing foreign languages data

创建一个饼图,显示 3 个最常用的语系

为了创建饼图,我检索了最常见的 3 个语系并将它们放入数据框中。

此代码组获取每个语系的母语人士总数,按降序排序,并提取前 3 个条目。

# get column names
columns = top_languages_table.find_all("th")
column_titles = [column.text.strip() for column in columns]

然后我将数据放入饼图中,指定“母语者”的 y 轴和图例,这为图表中显示的每个语言系列创建颜色编码标签。

# get table rows
table_data = top_languages_table.find_all("tr")

# define dataframe
df = pd.DataFrame(columns=column_titles)

# get table data
for row in table_data[1:]:
    row_data = row.find_all('td')
    row_data_txt = [row.text.strip() for row in row_data]
    print(row_data_txt)
    df.loc[len(df)] = row_data_txt 


Web scraping and analysing foreign languages data

其余问题的代码和回答可以在这里找到。我在笔记本中使用 Markdown 写下问题及其答案。

下次:

对于我的网络抓取和数据分析项目的下一次迭代,我想让事情变得更复杂:

  • 网络抓取动态页面,点击/滚动时会显示更多数据
  • 分析更大的数据集,可能需要在分析之前进行一些数据清理工作

Web scraping and analysing foreign languages data

最后的想法

尽管速度很快,但我很喜欢做这个项目。它提醒我,简短、可管理的项目对于让练习代表参与进来有多么有用?另外,从互联网提取数据并从中创建图表,即使数据集很小,也很有趣?

以上是网络抓取和分析外语数据的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
Python vs. C:了解关键差异Python vs. C:了解关键差异Apr 21, 2025 am 12:18 AM

Python和C 各有优势,选择应基于项目需求。1)Python适合快速开发和数据处理,因其简洁语法和动态类型。2)C 适用于高性能和系统编程,因其静态类型和手动内存管理。

Python vs.C:您的项目选择哪种语言?Python vs.C:您的项目选择哪种语言?Apr 21, 2025 am 12:17 AM

选择Python还是C 取决于项目需求:1)如果需要快速开发、数据处理和原型设计,选择Python;2)如果需要高性能、低延迟和接近硬件的控制,选择C 。

达到python目标:每天2小时的力量达到python目标:每天2小时的力量Apr 20, 2025 am 12:21 AM

通过每天投入2小时的Python学习,可以有效提升编程技能。1.学习新知识:阅读文档或观看教程。2.实践:编写代码和完成练习。3.复习:巩固所学内容。4.项目实践:应用所学于实际项目中。这样的结构化学习计划能帮助你系统掌握Python并实现职业目标。

最大化2小时:有效的Python学习策略最大化2小时:有效的Python学习策略Apr 20, 2025 am 12:20 AM

在两小时内高效学习Python的方法包括:1.回顾基础知识,确保熟悉Python的安装和基本语法;2.理解Python的核心概念,如变量、列表、函数等;3.通过使用示例掌握基本和高级用法;4.学习常见错误与调试技巧;5.应用性能优化与最佳实践,如使用列表推导式和遵循PEP8风格指南。

在Python和C之间进行选择:适合您的语言在Python和C之间进行选择:适合您的语言Apr 20, 2025 am 12:20 AM

Python适合初学者和数据科学,C 适用于系统编程和游戏开发。1.Python简洁易用,适用于数据科学和Web开发。2.C 提供高性能和控制力,适用于游戏开发和系统编程。选择应基于项目需求和个人兴趣。

Python与C:编程语言的比较分析Python与C:编程语言的比较分析Apr 20, 2025 am 12:14 AM

Python更适合数据科学和快速开发,C 更适合高性能和系统编程。1.Python语法简洁,易于学习,适用于数据处理和科学计算。2.C 语法复杂,但性能优越,常用于游戏开发和系统编程。

每天2小时:Python学习的潜力每天2小时:Python学习的潜力Apr 20, 2025 am 12:14 AM

每天投入两小时学习Python是可行的。1.学习新知识:用一小时学习新概念,如列表和字典。2.实践和练习:用一小时进行编程练习,如编写小程序。通过合理规划和坚持不懈,你可以在短时间内掌握Python的核心概念。

Python与C:学习曲线和易用性Python与C:学习曲线和易用性Apr 19, 2025 am 12:20 AM

Python更易学且易用,C 则更强大但复杂。1.Python语法简洁,适合初学者,动态类型和自动内存管理使其易用,但可能导致运行时错误。2.C 提供低级控制和高级特性,适合高性能应用,但学习门槛高,需手动管理内存和类型安全。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。