一种检测404软页面的分类器

soft404的Python项目详细描述


PyPI VersionBuild StatusCode Coverage

“软”404页是提供200个状态的页, 但实际上是一个说内容不可用的页面。

Installation

pip install soft404

Usage

最简单的方法是使用soft404.probability函数:

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

您还可以显式地创建分类器:

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

Development

对25k个领域的120k个页面进行分类器训练,404个页面比例约为1/3。 经10倍交叉验证,pr-auc(平均精密度)为0.990±0.003, roc-auc为0.995±0.002。

Getting data for training

安装开发要求:

pip install -r requirements_dev.txt

运行爬网程序一段时间(结果将显示在pages.jl.gz文件中):

cd crawler
scrapy crawl spider -o gzip:pages.jl -s JOBDIR=job

Training

首先,从html中提取文本和结构:

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

这将生成两个文件,items.meta.jl.gzitems.items.jl.gz。 接下来,训练分类器:

./soft404/train.py items

矢量器需要一段时间才能运行,但它的结果是缓存的(文件名 缓存位置将在下次运行时打印)。 如果您对结果满意,请保存分类器:

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

License

许可证是麻省理工学院的。

欢迎加入QQ群-->: 979659372 Python中文网_新手群

推荐PyPI第三方库


热门话题
java如何定制springdata存储库方法名称?   html有没有办法将java应用程序或JApplet嵌入到网站中?   Jackson ObjectMapper将java从字符串序列化为JSON作为namevalue   java刷新JTable?   用Java程序分发用JavaDB制作的数据库   java Android如何启动新活动   当集合大小超过500.000时,java的处理速度会显著降低   在java的分层目录中的多个目录中查找相同的文件   java如何将ArrayList数据插入数据库   java如何修改此代码,使其时间复杂度为o(logn)或o(n),而不是o(n^2)   java面板(SimplePanel)中仅显示图像的前1/3(大约),   jakarta ee Java Bean和企业Java Bean之间的区别?   创建AWS Cloudfront自签名URL(java sdk)时出现amazon web服务错误   基于Jersey和Jackson查询参数的java动态属性过滤