百独托管7500 紫田网络超高转化播放器收cps[推荐]速盾CDN 免实名免备防屏蔽阿里云 爆款特卖9.9元封顶提升alexa、IP流量7Q5团队
【腾讯云】中小企福利专场【腾讯云】多款产品1折起高防 随时退换 好耶数据小飞国外网赚带你月入万元炎黄网络4H4G10M 99每月
香港带宽CN2/美国站群优惠中客数据中心 服务器租用联盟系统移动广告平台 中易企业专场腾讯云服务器2.5折九九数据 工信部正规资质
腾讯云新用户大礼包代金券高价收cpa注册量高价展示【腾讯云】2核2G/9.93起租服务器找45互联 随时退换阿里云 短信服务 验证秒达

[其它内容] 如何使用WebBits和Haskell采集人人网 [复制链接]
查看:163 | 回复:0

1477

主题

1656

帖子

9

积分

落伍者(一心一意)

Rank: 1

贡献
685
鲜花
0
注册时间
2016-6-22

落伍者落伍微信绑定落伍手机绑定

发表于 2023-10-23 15:40:09 | 显示全部楼层 |阅读模式 来自 中国江苏淮安
33333.webp.jpg
大家好,前面给大家分享了关于采集人人网的相关代码的示例,今天给大家带来的也是一个采集人人网的爬虫实例,是通过WebBits和Haskell相结合,比较简洁,也非常易懂,让我们一起来学习一下。

```haskell

import Web.WebBits

import Network.HTTP.Conduit

import Data.Conduit

import Control.Monad.Trans.Resource

import Data.Maybe

import Data.List

import Data.Char

import System.Environment

main = do

proxy <- getProxy

let url = "http://www.renren.com"

response <- fetchUrl proxy url

case response of

Left err -> print err

Right doc -> do

let title = getTitle doc

print title

getProxy = do

proxies <- getProxyList

case proxies of

[] -> error "没有可用的代理服务器"

(x:xs) -> do

let proxy = "http://" ++ x

putStrLn $ "使用代理服务器: " ++ x

return proxy

getProxyList = do

url <- getUrl "https://www.duoip.cn/get_proxy"

let proxies = filter (not . null) $ map (stripPrefix "http://") $ lines url

return proxies

fetchUrl :: String -> String -> IO (Either String (HtmlUrl (Sink IO ())))

fetchUrl proxy url = do

manager <- newManager (tlsManagerSettings )

response <- fetchUrlWith manager url

return response

getTitle :: HtmlUrl (Sink IO ()) -> String

getTitle = fromMaybe "未知" . listToMaybe . concatMap (getTitle') . htmlUrlElements

getTitle' :: HtmlElement -> [String]

getTitle' (Element (Name "title") _ _) = ["标题"]

getTitle' _ = []

getUrl :: String -> IO String

getUrl url = do

response <- simpleHttp url

case response of

Left err -> error $ "请求失败: " ++ show err

Right doc -> return $ unpack $ responseBody doc

```

这个程序我们明显可以看出,不同于之前的代码,首先它会获取一个可用的代理地址,然后使用这个代理地址发送HTTP请求到网站服务器。接着,程序解析HTML内容,提取标题元素,并将其打印出来,除此之外,没有其他多余的操作。我们在实际使用时根据需要进行改动,完全可以直接运用,赶紧试试吧。
企业专线拨号VPS动态IP派克斯ADSL本地拨号,联系QQ174629754
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

论坛客服/商务合作/投诉举报:2171544 (QQ)
落伍者创建于2001/03/14,本站内容均为会员发表,并不代表落伍立场!
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论!
落伍官方微信:2030286 邮箱:(djfsys@gmail.com|tech@im286.com)
© 2001-2014

浙公网安备 33060302000191号

浙ICP备11034705号 BBS专项电子公告通信管[2010]226号

  落伍法律顾问: ITlaw-庄毅雄

手机版|找回帐号|不能发帖?|Archiver|落伍者

GMT+8, 2024-11-27 01:37 , Processed in 0.060206 second(s), 35 queries , Gzip On.

返回顶部