PyTeaser takes any news article and extract a brief summary from it. It's based on the original Scala project.
Summaries are created by ranking sentences in a news article according to how relevant they are to the entire text. The top 5 sentences are used to form a "summary". Each sentence is ranked by using four criteria:
- Relevance to the title
- Relevance to keywords in the article
- Position of the sentence
- Length of the sentence
Requires Python 2.7. (Need Collections.Counter)
pip install pyteaser
Note: if you're installing on Windows, you have to install one of the dependency package lxml manually using:
easy_install lxml==2.3.3
More information about this issue here: xiaoxu193#17
>>> from pyteaser import SummarizeUrl
>>> url = 'http://www.huffingtonpost.com/2013/11/22/twitter-forward-secrecy_n_4326599.html'
>>> summaries = SummarizeUrl(url)
>>> print summaries
[
'Twitter\'s move is the latest response from U.S. Internet firms following disclosures by former spy agency contractor Edward Snowden about widespread, classified U.S. government surveillance programs.',
'Since then, it has become clearer and clearer how important that step was to protecting our users\' privacy.',
'The online messaging service, which began scrambling communications in 2011 using traditional HTTPS encryption, said on Friday it has added an advanced layer of protection for HTTPS known as "forward secrecy.',
'"A year and a half ago, Twitter was first served completely over HTTPS," the company said in a blog posting.',
'By Jim Finkle (Reuters) - Twitter Inc said it has implemented a security technology that makes it harder to spy on its users and called on other Internet firms to do the same, as Web providers look to thwart spying by government intelligence agencies.'
]
you can use Summarize(title, text) directly if you already have the text and the title. Otherwise you must install Python Goose to extract text from url.