国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python實現(xiàn)的RSS閱讀器實例

2019-11-25 17:08:02
字體:
供稿:網(wǎng)友

本文實例講述了Python實現(xiàn)的RSS閱讀器。分享給大家供大家參考。具體如下:

# -*- coding:utf-8 -*-# file: pyRSS.py#import Tkinterimport urllibimport xml.parsers.expatclass MyXML: # XML解析類  def __init__(self, edit):    self.parser = xml.parsers.expat.ParserCreate() # 生成XMLParser    self.parser.StartElementHandler = self.start # 起始標(biāo)記處理方法    self.parser.EndElementHandler = self.end # 結(jié)束標(biāo)記處理方法    self.parser.CharacterDataHandler = self.data # 字符數(shù)據(jù)處理方法    self.title = False # 狀態(tài)標(biāo)志    self.description = False    self.date = False    self.edit = edit # 多行文本框?qū)ο? def start(self, name, attrs): # 起始標(biāo)記處理方法    if name == 'title': # 判斷是否為title元素      self.title = True # 標(biāo)志設(shè)為真    elif name == 'description':      self.description = True    elif name == 'pubDate': # 判斷是否為pubDate      self.date = True # 標(biāo)志設(shè)為真    else:      pass  def end(self, name): # 結(jié)束標(biāo)記處理    if name == 'title':      self.title = False # 標(biāo)志設(shè)為假    elif name == 'description':      self.description = False    elif name == 'pubDate':      self.date = False # 標(biāo)志設(shè)為假    else:      pass  def data(self,data): # 字符數(shù)據(jù)處理方法    if self.title: # 根據(jù)標(biāo)志狀態(tài)輸出數(shù)據(jù)      self.edit.insert(Tkinter.END,          '******************************/n')      self.edit.insert(Tkinter.END, 'Title: ')      self.edit.insert(Tkinter.END, data + '/n')    elif self.description:      self.edit.insert(Tkinter.END, 'Date: ')      self.edit.insert(Tkinter.END, data + '/n')    elif self.date:      self.edit.insert(Tkinter.END, 'Date: ')      self.edit.insert(Tkinter.END, data + '/n')    else:      pass  def feed(self, data):    self.parser.Parse(data, 0)class Window:  def __init__(self, root):    self.root = root # 創(chuàng)建組件    self.entryUrl = Tkinter.Entry(root,width = 30)    self.entryUrl.place(x = 65, y = 15)    self.get = Tkinter.Button(root,        text = '讀取RSS', command = self.Get, font = ('system','10'))    self.get.place(x = 350, y = 15)    self.frame = Tkinter.Frame(root, bd=2)    self.scrollbar = Tkinter.Scrollbar(self.frame)    self.edit = Tkinter.Text(self.frame,yscrollcommand = self.scrollbar.set,        width = 96, height = 32)    self.scrollbar.config(command=self.edit.yview)    self.edit.pack(side = Tkinter.LEFT)    self.scrollbar.pack(side=Tkinter.RIGHT, fill=Tkinter.Y)    self.frame.place(y = 50)  def Get(self):    url = self.entryUrl.get()    page = urllib.urlopen(url) # 打開URL    data = page.read() # 讀取URL內(nèi)容    parser = MyXML(self.edit) # 生成實例對象    parser.feed(data) # 處理XML數(shù)據(jù)    page.close()root = Tkinter.Tk()root.title('RSS 閱讀器')window = Window(root)root.minsize(700,500)root.maxsize(700,500)root.mainloop()

希望本文所述對大家的Python程序設(shè)計有所幫助。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 广丰县| 东宁县| 光泽县| 天门市| 广西| 泰兴市| 平山县| 东兴市| 深泽县| 滕州市| 东乡县| 竹溪县| 抚顺县| 泰和县| 千阳县| 南和县| 积石山| 阿拉尔市| 贵德县| 湖北省| 屏边| 津市市| 巴南区| 五家渠市| 苏州市| 云林县| 澎湖县| 遵化市| 昂仁县| 鹤岗市| 巴彦淖尔市| 东台市| 油尖旺区| 唐山市| 嵊州市| 建始县| 双牌县| 漯河市| 两当县| 庆元县| 巩留县|