Skip to content

trafilatura

783 2 38 GPLv3+
1.4.1 (19 Jan 2023) Jul 17 2019 208.6 thousand (month)

Trafilatura is a Python package and command-line tool designed to gather text on the Web. It includes discovery, extraction and text processing components. Its main applications are web crawling, downloads, scraping, and extraction of main texts, metadata and comments. It aims at staying handy and modular: no database is required, the output can be converted to various commonly used formats.

Going from raw HTML to essential parts can alleviate many problems related to text quality, first by avoiding the noise caused by recurring elements (headers, footers, links/blogroll etc.) and second by including information such as author and date in order to make sense of the data. The extractor tries to strike a balance between limiting noise (precision) and including all valid parts (recall). It also has to be robust and reasonably fast, it runs in production on millions of documents.

This tool can be useful for quantitative research in corpus linguistics, natural language processing, computational social science and beyond: it is relevant to anyone interested in data science, information extraction, text mining, and scraping-intensive use cases like search engine optimization, business analytics or information security.

Example Use


# it can be used to clean HTML files
from trafilatura import clean_html

html = '<html><head><title>My Title</title></head><body><p>This is some <b>bold</b> text.</p></body></html>'
cleaned_html = clean_html(html)
print(cleaned_html)

# can strip away tags:
clean_html(html, tags_to_remove=["title"])
# or attributes
clean_html(html, attributes_to_remove=["title"])

Alternatives / Similar


117,964 2021.12.17 (1 year, 2 months ago) Feb 22 2012 compare
1,357 2020.1.16 (3 years ago) Dec 14 2008 compare
2,222 0.8.1 (2 years ago) Jun 30 2011 compare
12,488 0.2.8 (4 years ago) Dec 28 2012 compare
733 0.14.0 (4 months ago) Oct 27 2015 compare
3,063 0.11.0 (4 months ago) Oct 20 2013 compare
46,721 0.4.1650 (2 months ago) Sep 01 2012 compare
9,417 1.1.9 (4 years ago) Aug 24 2018 compare
74 2.0.7 (3 months ago) Dec 11 2020 compare

Other Languages

2,090 v1.2.0 (26 days ago) Apr 20 2016 compare
1,956 v4.4.7 (2 months ago) Oct 26 2013 compare
313 2.0.30 (a month ago) Sep 11 2013 compare
764 3.5.4 (2 years ago) Mar 02 2013 compare