Skip to main content

A classifier for detecting soft 404 pages

Project description

PyPI Version Build Status Code Coverage

A “soft” 404 page is a page that is served with 200 status, but is really a page that says that content is not available.

Installation

pip install soft-404

Usage

The easiest way is to use the soft404.probability function:

>>> import soft404
>>> soft404.probability('<h1>Page not found</h1>')
0.9736860086882132

You can also create a classifier explicitly:

>>> from soft404 import Soft404Classifier
>>> clf = Soft404Classifier()
>>> clf.predict('<h1>Page not found</h1>')
0.9736860086882132

Development

Classifier is trained on 198801 pages from 35995 domains, with 404 page ratio of about 1/3. With 10-fold cross-validation, PR AUC (average precision) is 0.991 ± 0.002, and ROC AUC is 0.995 ± 0.002.

Getting data for training

Install dev requirements:

pip install -r requirements_dev.txt

Run the crawler for a while (results will appear in pages.jl.gz file):

cd crawler
scrapy crawl spider -o pages.jl.gz -t jl.gz -s JOBDIR=job

Training

First, extract text and structure from html:

./soft404/convert_to_text.py pages.jl.gz items

This will produce two files, items.meta.jl.gz and items.items.jl.gz. Next, train the classifier:

./soft404/train.py items

Vectorizer takes a while to run, but it’s result is cached (the filename where it is cached will be printed on the next run). If you are happy with results, save the classifier:

./soft404/train.py items --save soft404/clf.joblib

License

License is MIT.


define hyperiongray

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

soft-404-0.4.0.tar.gz (31.3 kB view details)

Uploaded Source

Built Distribution

soft_404-0.4.0-py2.py3-none-any.whl (30.9 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file soft-404-0.4.0.tar.gz.

File metadata

  • Download URL: soft-404-0.4.0.tar.gz
  • Upload date:
  • Size: 31.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/50.1.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.6.7

File hashes

Hashes for soft-404-0.4.0.tar.gz
Algorithm Hash digest
SHA256 1a549ae53e97f1b17718d54c96ce4b84baa8ac00f23ab7a78d177895f3fb4d30
MD5 4679e619e8d263e5de91e3af4c30c3bb
BLAKE2b-256 5c0e3c313d29f2f642f5f6afa75b54960d0f7ff7d75e714efbf17e827afdbf8a

See more details on using hashes here.

File details

Details for the file soft_404-0.4.0-py2.py3-none-any.whl.

File metadata

  • Download URL: soft_404-0.4.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 30.9 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/50.1.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.6.7

File hashes

Hashes for soft_404-0.4.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 e89384c161f7fcbbb3a5bba5aae7d409335b157e4d69b3d554244e51b767f6be
MD5 a1cdfd7c3286a6204a2c0a102d1d7947
BLAKE2b-256 bdc61960aa0dfe3875e69e07a62401cd459ca414d8595421f8bf4cc1696ffd93

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page