haxor
data:image/s3,"s3://crabby-images/9de45/9de4513b03195e6d321b7c30d92e96cd33cda52b" alt="license"
Unofficial Python wrapper for official Hacker News API.
Installation
pip install haxor
Usage
Import and initialization:
from hackernews import HackerNews
hn = HackerNews()
Items
Stories, comments, jobs, Ask HNs and even polls are just items with unique item id.
To query item information by id:
item = hn.get_item(8863)
Since most results are returned as integer IDs (like item.kids above), these results require further iteration. Instead of doing this yourself, use the expand
flag to get object-oriented, detailed item info by id:
item = hn.get_item(8863, expand=True)
To query a list of Item IDs:
items = hn.get_items_by_ids([8863, 37236, 2345])
Use the item_type
filter to specifically select 'story', 'comment', 'job', or 'poll' items:
items = hn.get_items_by_ids([8863, 37236, 2345], item_type='story')
Stories
The HN API allows for real-time querying for New, Top, Best, Ask HN, Show HN, and Jobs stories.
As an example, to get Item objects of current top stories:
top_stories = hn.top_stories()
Useful Item Queries
To get current largest Item id (most recent story, comment, job, or poll):
max_item = hn.get_max_item()
Once again, use the expand
flag to get an object-oriented, detailed Item representation:
max_item = hn.get_max_item(expand=True)
To get the x most recent Items:
last_ten = hn.get_last(10)
Users
HN users are also queryable.
To query users by user_id (i.e. username on Hacker News):
user = hn.get_user('pg')
Use the expand
flag to get an object-oriented, detailed Item representation for User attributes:
user = hn.get_user('dhouston', expand=True)
To query a list of users:
users = hn.get_users_by_ids(['pg','dhouston'])
Examples
Get top 10 stories:
hn.top_stories(limit=10)
Find all the 'jobs' post from Top Stories:
stories = hn.top_stories()
for story in stories:
if story.item_type == 'job':
print(story)
Find Python jobs from monthly who is hiring thread:
who_is_hiring = hn.get_item(16735011, expand=True)
for comment in who_is_hiring.kids:
if 'python' in comment.text.lower():
print(comment)
API Reference
Class: HackerNews
Parameters:
Name | Type | Required | Description | Default |
---|
version | string | No | specifies Hacker News API version | v0 |
get_item
Description: Returns Item
object
Parameters:
Name | Type | Required | Description | Default |
---|
item_id | string/int | Yes | unique item id of Hacker News story, comment etc | None |
expand | bool | No | flag to indicate whether to transform all IDs into objects | False |
get_items_by_ids
Description: Returns list of Item
objects
Parameters:
Name | Type | Required | Description | Default |
---|
item_ids | list of string/int | Yes | unique item ids of Hacker News stories, comments etc | None |
item_type | string | No | item type to filter results with | None |
get_user
Description: Returns User
object
Parameters:
Name | Type | Required | Description | Default |
---|
user_id | string | Yes | unique user id of a Hacker News user | None |
expand | bool | No | flag to indicate whether to transform all IDs into objects | False |
get_users_by_ids
Description: Returns list of User
objects
Parameters:
Name | Type | Required | Description | Default |
---|
user_ids | list of string/int | Yes | unique user ids of Hacker News users | None |
top_stories
Description: Returns list of Item
objects of current top stories
Parameters:
Name | Type | Required | Description | Default |
---|
raw | bool | No | indicate whether to represent all objects in raw json | False |
limit | int | No | specifies the number of stories to be returned | None |
new_stories
Description: Returns list of Item
objects of current new stories
Parameters:
Name | Type | Required | Description | Default |
---|
raw | bool | No | indicate whether to represent all objects in raw json | False |
limit | int | No | specifies the number of stories to be returned | None |
ask_stories
Description: Returns list of Item
objects of latest Ask HN stories
Parameters:
Name | Type | Required | Description | Default |
---|
raw | bool | No | indicate whether to represent all objects in raw json | False |
limit | int | No | specifies the number of stories to be returned | None |
show_stories
Description: Returns list of Item
objects of latest Show HN stories
Parameters:
Name | Type | Required | Description | Default |
---|
raw | bool | No | indicate whether to represent all objects in raw json | False |
limit | int | No | specifies the number of stories to be returned | None |
job_stories
Description: Returns list of Item
objects of latest Job stories
Parameters:
Name | Type | Required | Description | Default |
---|
raw | bool | No | indicate whether to represent all objects in raw json | False |
limit | int | No | specifies the number of stories to be returned | None |
updates
Description: Returns list of Item
and User
objects that have been changed/updated recently.
Parameters:
N/A
get_max_item
Description: Returns current largest item id or current largest Item
object
Parameters:
Name | Type | Required | Description | Default |
---|
expand | bool | No | flag to indicate whether to transform ID into object | False |
get_all
Description: Returns all Item
objects from HN
Parameters:
N/A
get_last
Description: Returns list of num
most recent Item
objects
Parameters:
Name | Type | Required | Description | Default |
---|
num | int | No | numbr of most recent records to pull from HN | 10 |
Class: Item
From Official HackerNews
Item:
Property | Description |
---|
item_id | The item’s unique id. |
deleted | true if the item is deleted. |
item_type | The type of item. One of “job”, “story”, “comment”, “poll”, or “pollopt”. |
by | The username of the item’s author. |
submission_time | Creation date of the item, in Python datetime . |
text | The comment, Ask HN, or poll text. HTML. |
dead | true if the item is dead. |
parent | The item’s parent. For comments, either another comment or the relevant story. For pollopts, the relevant poll. |
poll | The ids of poll's. |
kids | The ids of the item’s comments, in ranked display order. |
url | The URL of the story. |
score | The story’s score, or the votes for a pollopt. |
title | The title of the story or poll. |
parts | A list of related pollopts, in display order. |
descendants | In the case of stories or polls, the total comment count. |
raw | original JSON response. |
Class: User
From Official HackerNews
User:
Property | Description |
---|
user_id | The user’s unique username. Case-sensitive. |
delay | Delay in minutes between a comment’s creation and its visibility to other users. |
created | Creation date of the user, in Python datetime . |
karma | The user’s karma. |
about | The user’s optional self-description. HTML. |
submitted | List of the user’s stories, polls and comments. |
raw | original JSON response. |
Additional properties when expand
is used
Property | Description |
---|
stories | The user’s submitted stories. |
comments | The user's submitted comments. |
jobs | The user's submitted jobs. |
polls | The user's submitted polls. |
pollopts | The user's submitted poll options. |
Development
For local development do pip
installation of requirements-dev.txt
:
pip install -r requirements-dev.txt
Testing
Run the test suite by running:
echo "0.0.0-dev" > version.txt
python setup.py develop
pytest tests
LICENSE
The mighty MIT license. Please check LICENSE
for more details.