a module for polling urls and stats from homepages
Project description
pageone ====== a module for polling urls and stats from homepages
Install
pip install pageone
Test
Requires nose
nosetests
Usage
pageone does two things: extract article urls from a site’s homepage and also uses selenium and phantomjs to find the relative positions of these urls.
To get stats about the positions of links, use link_stats:
from pageone import PageOne
p = PageOne(url='http://www.propublica.org/')
# get stats about links positions
for link in p.link_stats():
print link
This will return a list of dictionaries that look like this:
{
'bucket': 4,
'datetime': datetime.datetime(2014, 6, 7, 16, 6, 3, 533818),
'font_size': 13,
'has_img': 1,
'headline': u'',
'homepage': 'http://www.propublica.org/',
'img_area': 3969,
'img_height': 63,
'img_src': u'http://www.propublica.org/images/ngen/gypsy_image_medium/mpmh_victory_drive_140x140_130514_1.jpg',
'img_width': 63,
'url': u'http://www.propublica.org/article/protect-service-members-defense-department-plans-broad-ban-high-cost-loans',
'x': 61,
'x_bucket': 1,
'y': 730,
'y_bucket': 4
}
Here bucket variables represent where a link falls in 200x200 pixel grid. For x_bucket this number moves from left-to-right. For y_bucket, it moves top-to-bottom. bucket moves from top-left to bottom right. You can customize the size of this grid by passing in bucket_pixels to link_stats, eg:
from pageone import PageOne
p = PageOne(url='http://www.propublica.org/')
# get stats about links positions
for link in p.link_stats(bucket_pixels = 100):
print link
To get simply get all of the article urls on a homepage, use articles:
from pageone import PageOne
p = PageOne(url='http://www.propublica.org/')
for article in p.articles():
print article
If you want to get article urls from other sites, use incl_external:
from pageone import PageOne
p = PageOne(url='http://www.propublica.org/')
for article in p.articles(incl_external=True):
print article
How do I know which urls are articles?
pageone uses siegfried for url parsing and validation. If you want to apply a custom regex for article url validation, you can pass in a pattern to either link_stats or articles, eg:
from pageone import PageOne
import re
pattern = re.compile(r'.*propublica.org/[a-z]+/[a-z0-9/-]+')
p = PageOne(url='http://www.propublica.org/')
for article in p.articles(pattern=pattern):
print article
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file pageone-0.0.9.tar.gz
.
File metadata
- Download URL: pageone-0.0.9.tar.gz
- Upload date:
- Size: 5.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6401262508c4795712bdc8b963384dae499a8646dd77ca55ceafc3399f4889d5 |
|
MD5 | b0ed80babb4c33d91453e97e05b0114e |
|
BLAKE2b-256 | da48bfa796bcb8aedf4a11bf8f6941e747c44b10126793b35fd52a0b28fe5b77 |
File details
Details for the file pageone-0.0.9.macosx-10.9-intel.exe
.
File metadata
- Download URL: pageone-0.0.9.macosx-10.9-intel.exe
- Upload date:
- Size: 70.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b24faf16e7dafc6f84ef50cc1e2f8b3a9f676f1116ea990ada4c79491d7f7569 |
|
MD5 | 7223ba3b9541412350decb6187e812b3 |
|
BLAKE2b-256 | b96b0ebcfe55bb2bfa2497805ae0998943450e575fed7712720e7bb8d635714a |