麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Python > 正文

python基礎(chǔ)教程項(xiàng)目四之新聞聚合

2019-11-02 14:06:24
字體:
供稿:網(wǎng)友

《python基礎(chǔ)教程》書中的第四個練習(xí),新聞聚合。現(xiàn)在很少見的一類應(yīng)用,至少我從來沒有用過,又叫做Usenet。這個程序的主要功能是用來從指定的來源(這里是Usenet新聞組)收集信息,然后講這些信息保存到指定的目的文件中(這里使用了兩種形式:純文本和html文件)。這個程序的用處有些類似于現(xiàn)在的博客訂閱工具或者叫RSS訂閱器。

先上代碼,然后再來逐一分析:

from nntplib import NNTPfrom time import strftime,time,localtimefrom email import message_from_stringfrom urllib import urlopenimport textwrapimport reday = 24*60*60def wrap(string,max=70):    '''    '''    return '/n'.join(textwrap.wrap(string)) + '/n'class NewsAgent:    '''    '''    def __init__(self):        self.sources = []        self.destinations = []    def addSource(self,source):        self.sources.append(source)    def addDestination(self,dest):        self.destinations.append(dest)    def distribute(self):        items = []        for source in self.sources:            items.extend(source.getItems())        for dest in self.destinations:            dest.receiveItems(items)class NewsItem:    def __init__(self,title,body):        self.title = title        self.body = bodyclass NNTPSource:    def __init__(self,servername,group,window):        self.servername = servername        self.group = group        self.window = window    def getItems(self):        start = localtime(time() - self.window*day)        date = strftime('%y%m%d',start)        hour = strftime('%H%M%S',start)        server = NNTP(self.servername)        ids = server.newnews(self.group,date,hour)[1]        for id in ids:            lines = server.article(id)[3]            message = message_from_string('/n'.join(lines))            title = message['subject']            body = message.get_payload()            if message.is_multipart():                body = body[0]            yield NewsItem(title,body)        server.quit()class SimpleWebSource:    def __init__(self,url,titlePattern,bodyPattern):        self.url = url        self.titlePattern = re.compile(titlePattern)        self.bodyPattern = re.compile(bodyPattern)    def getItems(self):        text = urlopen(self.url).read()        titles = self.titlePattern.findall(text)        bodies = self.bodyPattern.findall(text)        for title.body in zip(titles,bodies):            yield NewsItem(title,wrap(body))class PlainDestination:    def receiveItems(self,items):        for item in items:            print item.title            print '-'*len(item.title)            print item.bodyclass HTMLDestination:    def __init__(self,filename):        self.filename = filename    def receiveItems(self,items):        out = open(self.filename,'w')        print >> out,'''        <html>        <head>         <title>Today's News</title>        </head>        <body>        <h1>Today's News</hi>        '''        print >> out, '<ul>'        id = 0        for item in items:            id += 1            print >> out, '<li><a href="#" rel="external nofollow" >%s</a></li>' % (id,item.title)        print >> out, '</ul>'        id = 0        for item in items:            id += 1            print >> out, '<h2><a name="%i">%s</a></h2>' % (id,item.title)            print >> out, '<pre>%s</pre>' % item.body        print >> out, '''        </body>        </html>        '''def runDefaultSetup():    agent = NewsAgent()    bbc_url = 'http://news.bbc.co.uk/text_only.stm'    bbc_title = r'(?s)a href="[^" rel="external nofollow" ]*">/s*<b>/s*(.*?)/s*</b>'    bbc_body = r'(?s)</a>/s*<br/>/s*(.*?)/s*<'    bbc = SimpleWebSource(bbc_url, bbc_title, bbc_body)    agent.addSource(bbc)    clpa_server = 'news2.neva.ru'    clpa_group = 'alt.sex.telephone'    clpa_window = 1    clpa = NNTPSource(clpa_server,clpa_group,clpa_window)    agent.addSource(clpa)    agent.addDestination(PlainDestination())    agent.addDestination(HTMLDestination('news.html'))    agent.distribute()if __name__ == '__main__':    runDefaultSetup()
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 鲁人人人鲁人人鲁精品 | 娇喘视频在线观看 | 毛片一级网站 | 国产69精品久久久久9999不卡免费 | 久久亚色 | 亚洲综合一区在线观看 | 国产精品久久久久久久久久久久午夜 | 毛片免费视频 | 久久免费看片 | 精品一区二区三区欧美 | 久色一区| 羞羞网站在线观看入口免费 | 毛片网站网址 | 九九精品在线播放 | 怦然心动50免费完整版 | 黄色高清免费网站 | 中文字幕电影免费播放 | 伊人二本二区 | 免费视频a | 国产三级精品最新在线 | 欧美一级美片在线观看免费 | 热99精品视频 | 国产美女视频黄a视频免费 日韩黄色在线播放 | 久久免费观看一级毛片 | 日日草夜夜操 | 免费观看欧美一级片 | 午夜在线观看视频网站 | 特级西西444www大精品视频免费看 | 精品在线观看一区二区 | 国产精品久久久久国产精品三级 | 三人弄娇妻高潮3p视频 | 午夜精品视频在线 | 国产porn在线 | 欧美日韩爱爱视频 | 奶子吧naiziba.cc免费午夜片在线观看 | 国产黄色网 | 一级黄片毛片免费看 | 日韩av在线资源 | 一级外国毛片 | 99在线在线视频免费视频观看 | 久久精品免费国产 |