牛人博客!!!各大招聘网站信息实时查询浏览【转】

转自:http://www.cnblogs.com/zhaopei/p/4368417.html

阅读目录

 

      最近听得较多的跳槽、面试之类的,相信很多园友也开始蠢蠢欲动了,有的甚至早已经开始了。最近我也在琢磨着换工作的事。说得俗套点,人在外面不就为了那么点工资么。现在找工作大部分都是通过在网上投简历,然后等电话 通知面试的。然,现在的招聘网站也是比较多。一个一个的在各大网站切换的流量招聘信息 实属麻烦。之前看到过一篇博文。《找工作神器,提取各大网站有效的招聘信息(前程无忧、智联招聘、猎聘网)》感觉这想法挺好的。把各大网站信息集中起来浏览,第一省了来回切换,第二还不容易重复投简历。本想拿来用用的,无奈没有提供源码下载,且是客户端版本。于是就只能自己动手,丰衣足食了~。(网站就是强大,可以大家一起分享●0●^_^)

     合并查询本来就是为了简单方便,所以也就没有弄很复杂了,一个页面搞定。如果同学们有什么好的想法,可以建议建议。

效果图:

就一个简单的关键字输入框、工作地点的选择和信息来源网站。

其实看上去很简单,实现起来也很简单。~~代码不多,难度也很小。很多时候需要的技术不是很多,想法更重要。

不想往下看的可以直接用用 演示地址 ,同学们求工作给推荐推荐,上海 浦东 .net。 私密我,或Q我。

 

第一、分析url

进入招聘网站的时候url大串大串的,我们需要用的的就三个。搜索关键字、地址和页码。

智联招聘:

http://sou.zhaopin.com/jobs/searchresult.ashx?jl=地址&kw=关键字&p=页码

jl=地址

kw=关键字

p=页码

然后地址的话 直接中文地址就ok了

猎聘网:

http://www.liepin.com/zhaopin/?key=关键字&dqs=地址&curPage=页码

key=关键字

dqs=地址

curPage=页码

地址有一个对应的编号

("北京", "010");
("上海", "020");
("广州", "050020");...等等  也是在猎聘网选择地址的地方右键 审查元素可以看到,如下:

前程无忧:

http://search.51job.com/jobsearch/search_result.php?jobarea=地址&keyword=关键字&curr_page=页码

jobarea=地址 [和猎聘一样的查找方法]

keyword=关键字

curr_page=页码

第二、用到了HtmlAgilityPack.DLL HTML解析组件

在之前我发过的 博客转发小工具 有提过HtmlAgilityPack。这里再简单的说说用法。

case ZhaopinType.猎聘网:
    var htmlWeb = new HtmlWeb();
    htmlWeb.OverrideEncoding = Encoding.GetEncoding("UTF-8");
    HtmlAgilityPack.HtmlDocument response = htmlWeb.Load(url);
    #region MyRegion
    var ulS = response.DocumentNode.SelectNodes("//*[@id='sojob']/div[2]/div/div/ul/li");
    foreach (var item in ulS)
    {
        var xpath = item.XPath;
        string titleName, infourl, company, city, date, salary, salary_em, source;
        titleName = item.SelectSingleNode(xpath + "/a").Attributes["title"].Value;
        infourl = item.SelectSingleNode(xpath + "/a").Attributes["href"].Value;
        company = item.SelectSingleNode(xpath + "/a/dl/dt[@class='company']").InnerText;
        city = item.SelectSingleNode(xpath + "/a/dl/dt[@class='city']/span").InnerText;
        date = item.SelectSingleNode(xpath + "/a/dl/dt[@class='date']/span").InnerText;
        salary = item.SelectSingleNode(xpath + "/a/dl/dt[@class='salary']/span").InnerText;
        salary_em = item.SelectSingleNode(xpath + "/a/dl/dt[@class='salary']/em").InnerText;
        source = "猎聘网";

        zpInfoList.Add(
            new ZhaopinInfo()
            {
                city = city,
                company = company,
                date = date,
                info_url = infourl,
                salary = salary,
                salary_em = salary_em,
                titleName = titleName,
                source = source
            });
    }
    #endregion
    break;

1.设置访问url页面的编码

 htmlWeb.OverrideEncoding = Encoding.GetEncoding("UTF-8");

设置编码为UTF-8,具体看对应页面采用的编码。

2.元素路径下的元素集合

var ulS = response.DocumentNode.SelectNodes("//*[@id='sojob']/div[2]/div/div/ul/li");

SelectNodes方法里面的这串字符串怎么来?

右键审查元素 Copy XPath 就ok了。不过如果js有动态修改document树的话 那么这个路径就不准了,需要自己微调下。

3、取标签的属性值 Attributes

如:取a标签的title值。

titleName = item.SelectSingleNode(xpath + "/a").Attributes["title"].Value;

4.取标签的中间的文本 InnerText

company = item.SelectSingleNode(xpath + "/a/dl/dt[@class='company']").InnerText;

5.过滤选择特定的id 或 class

XPath 中 标签名后面加上中括号 和@ 如: "/a/dl/dt[@class='company']"

第三、浏览器滚动条的onscroll事件

js获取滚动条距离浏览器顶部,底部的高度,兼容ie和firefox

取窗口可视范围的高度[浏览器可见区域高度]

//取窗口可视范围的高度[浏览器可见区域高度]
        getClientHeight: function () {
            var clientHeight = 0;
            if (document.body.clientHeight && document.documentElement.clientHeight) {
                var clientHeight = (document.body.clientHeight < document.documentElement.clientHeight) ? document.body.clientHeight : document.documentElement.clientHeight;
            } else {
                var clientHeight = (document.body.clientHeight > document.documentElement.clientHeight) ? document.body.clientHeight : document.documentElement.clientHeight;
            }
            return clientHeight;
        }

取窗口滚动条高度[滚动条距离顶部的高度]

  getScrollTop: function () {
            var scrollTop = 0;
            if (document.documentElement && document.documentElement.scrollTop) {
                scrollTop = document.documentElement.scrollTop;
            } else if (document.body) {
                scrollTop = document.body.scrollTop;
            }
            return scrollTop;
        }

 

取文档内容实际高度

  getScrollHeight: function () {
            return Math.max(document.body.scrollHeight, document.documentElement.scrollHeight);
        }

 

滚动条距离底部的高度

getScrollbheight: function () { return this.getScrollHeight() - this.getScrollTop() - this.getClientHeight(); }

 

 取滚动条距离底部的高度,当滚动条到最底部的时候,通过ajax异步请求后台,加载下一页数据,这样就可以免了翻页的麻烦了。

 

ps:用jquery 更加简洁(感谢@Samguist

if ($(window).scrollTop() == $(document).height() - $(window).height()) {
// ajax异步加载数据
}

 

 

 

基本上就是这样简单,没什么难度。记得有什么好工作通知一声哦~^_^ ^_^   ***** 点击本人求职信息*****

环境:vs2013   数据库:无   插件:HtmlAgilityPack   演示地址  源码下载  (源码都下了 顺手点个赞呗~)

时间: 2024-09-30 07:17:13

牛人博客!!!各大招聘网站信息实时查询浏览【转】的相关文章

计算机视觉领域的一些牛人博客,超有实力的研究机构等的网站链接

以下链接是本人整理的关于计算机视觉(ComputerVision, CV)相关领域的网站链接,其中有CV牛人的主页,CV研究小组的主页,CV领域的paper,代码,CV领域的最新动态,国内的应用情况等等.打算从事这个行业或者刚入门的朋友可以多关注这些网站,多了解一些CV的具体应用.搞研究的朋友也可以从中了解到很多牛人的研究动态.招生情况等.总之,我认为,知识只有分享才能产生更大的价值,真诚希望下面的链接能对朋友们有所帮助.(1)googleResearch: http://research.go

计算机视觉领域的一些牛人博客,研究机构等的网站链接

    转自:http://www.cnblogs.com/Rick-w/archive/2012/04/14/2446921.html        以下链接是本人整理的关于计算机视觉(ComputerVision, CV)相关领域的网站链接,其中有CV牛人的主页,CV研究小组的主页,CV领域的paper,代码,CV领域的最新动态,国内的应用情况等等.打算从事这个行业或者刚入门的朋友可以多关注这些网站,多了解一些CV的具体应用.搞研究的朋友也可以从中了解到很多牛人的研究动态.招生情况等.总之,

好好经营博客一样能让网站得到更高权重

大家都知道网站权重的重要性,那我们怎么提升网站的权重呢?除了本身网站的更新和维护外,我们可以同时做好企业博客的维护和推广工作,起到帮助主站的权重提升. 很多人都说博客现在权重没那么高了,不过只要对我们的网站有帮助,自己证明起作用的方法都要坚持去做.博客难养可能是事实,博客权重也不是通过几天个把月能建立起来的,如果马上就能见效我想也就失去了博客的作用了,其实,任何事情考验的是我们的恒心和决心. 今天,我来简单分享下景航科技是怎样经营博客的,如何更好的让博客具备更高的权重传递到我们的主站呢,同时也起

独立博客带给行业网站的启示

独立博客和行业网站(注:指某个行业的综合性门户类网站,不同于博客形式,暂时想不到更好的名词来表述)都在发表着各式各样的观点,在这一点上,它们是相同的,但在其他方面,又有所不同.独立博客虽然在人力.财力等方面往往都不及行业网站,但有自己的优势,影响力也未必更弱.独立博客往往由一个或几个作者维护,有的独立博客接受投稿,有的独立博客都是原创. 独立博客中以一个人的博客居多.一个人的独立博客的站长又往往是名人.对一个人的博客来说,不论是在原创还是在选稿,都较能体现出个人的品味和眼光,容易形成特有风格.一

博客群建与网站群建的轮链模式有什么区别

利用给博客和网站更新文章的时间里,决定给博客写点东西,有感而发:因为平时QQ交流中有朋友对博客群建和网站群建的模式好像有些混淆,认为群建博客(这里说的是下图中所示的免费博客),就是为了给网站做外链,做100个或者几百个,全部链向要优化的网站,这样的想法是很正确的,但博客群建也要遵循轮链的规则,否则博客同样会被搜索引擎丢弃,对待博客群建,做法与网站群建的策略相似,同样是要分层次来进行,这样可以有效提高单个博客权重以及整体的权重,有朋友就不理解分层次,分层次就是根据金字塔链轮模式来定的,有兴趣的朋友

让独立博客排名飞起来网站优化细节

一:博客的流量来源分析 在网站优化中,博客是一个特殊的例子,可以不去依靠搜索引擎而轻易引导流量的产生.早期一般由门户博客所带出博客的互访,直到目前独立博客之间的相互评论.就一个SEO优化博客而言,对于这一点可以毫不夸张的说,其中至少有50%以上的流量来源于"互动".每天为100个博客去互踩留言,其中绝大多数的博主都会出于礼貌性的回访,于是一个月下来便可积累出30000的可回访博客源.此后不用再继续做新的博客评论,只需在这其中轮流转一圈,每天来的流量将是客观的.诸如现在一些名博,绝大的流

流量就在你脚下之博客推广大总结

中介交易 SEO诊断 淘宝客 云主机 技术大厅 从一开始人们就在议论到底我们应该怎样在博客上获取流量,很多朋友以前也是给了很多办法,有人成功,有人失败.那么究竟如何在这些博客平台上获取流量,为自己所用呢?虽然网上已经有大量的文章介绍了如何推广博客,但大多都是写的比较浅显,没什么实在的效果. 为了让大家掌握真正有效的免费博客流量方法,天天源码网把比较有效的博客推广方法做一下总结供大家参考. 1:关键词优化 内外兼修. 博客平台内部优化: 在博客平台都有站内搜索,想获取站内搜索的流量非常简单,参考博

新浪博客开发者平台的网站接入如何填写?

问题描述 新浪博客开发者平台的网站接入如何填写? 10C 新浪博客开发者平台的网站接入如何填写?它需要填写两个信息,网站名称和网站域名,我在网站名称上填了自己博客的title名字,然后将主页的url黏贴到网站域名上,结果它说我网站域名格式不对,请问有没有申请成功过的伙伴指点一下~~ 另外一个问题是,这个网站接入是什么意思?是指获取数据的入口吗? 解决方案 你按照人家的要求填写没有 请填写网站域名.不含http://如果您希望把所有子域名均归于同一网站,则只需填写根域名,比如:a.weibo.co

浅谈合理利用第三方博客群来推广网站

中介交易 http://www.aliyun.com/zixun/aggregation/6858.html">SEO诊断 淘宝客 云主机 技术大厅 网站推广是一个永远不会消褪的热点话题,不管是企业,还是个人站长都很关注网站推广,都很看中推广的方式.推广的效果等等.其实网上的推广方法介绍了很多,但是很多还是需要靠站长们亲自去实践,去总结,方能成为自己的一份财富.笔者写这篇文章主要是针对第三方博客的推广,这种推广方式笔者相信很多站长都在运用,而且都是利用博客群的方式在推广.下面就由小吴来给大