获取CSDN论坛帖子列表

*!* 作  者:十豆三
*!* 日  期:2010-06-30
*!* 说  明:本例是获取VFP版的帖子列表,同理也可以获取其他版块的帖子列表。

 

Set Century On
Set Date
YMD
Create Cursor CSDN_VFP (帖子标题 C(254),帖子链接 C(254),发帖人 C(50),发帖时间 T,发帖星期 C(6),更新时间 T) && CSDN没有提供 帖子分数、回复数和最后回复人
Declare Integer DeleteUrlCacheEntry In Wininet.Dll String szUrl
lcCSDNXML="http://forum.csdn.net/Rss/VFP/UnClosedList/"
&& 更改此链接可以获取其他版块的帖子列表
=DeleteUrlCacheEntry(lcCSDNXML) && 清理缓存
loXMLHTTP=Newobject("Microsoft.XMLHTTP")
loXMLHTTP.
Open("get",lcCSDNXML,.F.) && 最近200个帖子
loXMLHTTP.Send()
*!* =Strtofile(loXMLHTTP.responseBody,"C:/CSDN_VFP.xml")
loDom=Newobject("Msxml2.DOMDocument")
loDom.
LoadXML(loXMLHTTP.responseText)
lnItemCount=loDom.SelectNodes("/rss/channel/item").Length
For lnI=0 To lnItemCount-1
    lcpubDate=loDom.SelectNodes("/rss/channel/item/pubDate").
Item(lnI).Text && 发帖星期及英文日期
    Insert Into CSDN_VFP Values (;
        loDom.SelectNodes("/rss/channel/item/title").
Item(lnI).Text,; && 帖子标题
       
loDom.SelectNodes("/rss/channel/item/link").Item(lnI).Text,; && 帖子链接
       
loDom.SelectNodes("/rss/channel/item/a10:author/a10:name").Item(lnI).Text,; && 发帖人
       
Ctot(Substr(lcpubDate,13,4)+"-"+Padl(Ceiling(At(Substr(lcpubDate,9,3),"JanFebMarAprMayJunJulAugSepOctNovDec")/3),2,"0")+"-"+Substr(lcpubDate,6,2)+Substr(lcpubDate,17,9)),; && 发帖时间
       
"星期"+Substrc("一二三四五六日",Ceiling(At(Substr(lcpubDate,1,3),"MonTueWedThuFriSatSun")/3),1),; && 发帖星期
       
Ctot(Chrtran(loDom.selectNodes("/rss/channel/item/a10:updated").Item(lnI).Text,[TZ],Space(1)))+8*60*60; && 更新时间
       
)
Endfor
Locate
Browse
Release
loXMLHTTP,loDom

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值