Python實(shí)現(xiàn)的RSS閱讀器實(shí)例
更新時(shí)間:2015年07月25日 10:37:54 作者:Sephiroth
這篇文章主要介紹了Python實(shí)現(xiàn)的RSS閱讀器,實(shí)例分析了XML解析實(shí)現(xiàn)RSS閱讀的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
本文實(shí)例講述了Python實(shí)現(xiàn)的RSS閱讀器。分享給大家供大家參考。具體如下:
# -*- coding:utf-8 -*-
# file: pyRSS.py
#
import Tkinter
import urllib
import xml.parsers.expat
class 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) # 生成實(shí)例對(duì)象
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()
希望本文所述對(duì)大家的Python程序設(shè)計(jì)有所幫助。
相關(guān)文章
用Python把csv文件批量修改編碼為UTF-8格式并轉(zhuǎn)為Excel格式的方法
有時(shí)候用excel打開一個(gè)csv文件,中文全部顯示亂碼,然后手動(dòng)用notepad++打開,修改編碼為utf-8并保存后,再用excel打開顯示正常,本文將給大家介紹一下用Python把csv文件批量修改編碼為UTF-8格式并轉(zhuǎn)為Excel格式的方法,需要的朋友可以參考下2023-09-09
Python求一批字符串的最長(zhǎng)公共前綴算法示例
這篇文章主要介紹了Python求一批字符串的最長(zhǎng)公共前綴算法,涉及Python針對(duì)字符串的遍歷、判斷、計(jì)算等相關(guān)操作技巧,需要的朋友可以參考下2019-03-03
pandas-resample按時(shí)間聚合實(shí)例
今天小編就為大家分享一篇pandas-resample按時(shí)間聚合實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12
python 去除二維數(shù)組/二維列表中的重復(fù)行方法
今天小編就為大家分享一篇python 去除二維數(shù)組/二維列表中的重復(fù)行方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-01-01
使用Python獲取字典鍵對(duì)應(yīng)值的兩種方法
對(duì)于字典通過(guò)鍵獲得值非常簡(jiǎn)單,但通過(guò)值獲得鍵則需繞些彎子,下面這篇文章主要給大家介紹了關(guān)于如何使用Python獲取字典鍵對(duì)應(yīng)值的相關(guān)資料,需要的朋友可以參考下2022-04-04
深入淺析Python數(shù)據(jù)分析的過(guò)程記錄
我們先利用?Jupyter?Notebook?來(lái)進(jìn)行分析,然后,在得到成果以后,利用?Pycharm?來(lái)進(jìn)行完整的程序設(shè)計(jì),對(duì)Python數(shù)據(jù)分析的過(guò)程記錄感興趣的朋友一起看看吧2022-01-01
YOLOv5改進(jìn)系列之增加小目標(biāo)檢測(cè)層
yolov5出來(lái)已經(jīng)很長(zhǎng)時(shí)間了,所以有關(guān)yolov5的一些詳細(xì)介紹在這里就不一一介紹了,下面這篇文章主要給大家介紹了關(guān)于YOLOv5改進(jìn)系列之增加小目標(biāo)檢測(cè)層的相關(guān)資料,需要的朋友可以參考下2022-09-09

