怎样在input里加入搜索_手把手教你使用Python打造一款简易搜索引擎

点击上方“ Python爬虫与数据挖掘 ”,进行关注

回复“书籍”即可获赠Python从入门到进阶共10本电子书

 一去紫台连朔漠,独留青冢向黄昏。

/1 前言/

    相信大家在知识共享的这个年代一定在网上下载了很多的文件保存以供日后有时间学习吧,毕竟硬盘空间也比较有限,下面我们就来说说我们要做的这个项目,就是搜索盘搜里的资源然后进行下载。

/2 项目目标/

    实现搜索自己想要的文件,并且下载文件。

/3 项目准备/

    使用sublime text 3 开发。因为此次我们需要用到交互式来完成操作,所以需要在sublime text 3 下载一个sublimeREPL插件来进行辅助开发。

/4 项目实现/

1、打开盘搜,并随意打开一个链接,如下图所示:

27af13dbb8d28d1c52c5ba47b88967a7.png

2、然后可以看到这个画面,如下图所示。

3939f1ec247faf2b34f8f99d409e1d28.png

3、此时这个网页地址为:
http://www.pansou.com/?q=成化十四年
由此可以看出它是一个get请求。于是requests.get搞起来,这样我们就实现了第一步,搜索。于是,可以这样写代码:
import requests def down(content):  content=input('请输入要下载的文件名')  rep=requests.get('http://www.pansou.com/?q='+str(content))  rep.encoding='utf-8'
4、这样就得到了上个页面中的网页源代码,我们通过搜索相关关键字发现竟然搜不到:

c34550f8e79b08d6c720633967c99019.png

5、那么这是怎么回事?原来这是因为ajax异步加载导致的部分关键代码显示不出来。这可就犯难了,换句话说这就触及到我的知识点盲区了。
因为小编并未学过前端,只知道有ajax这回事,哪里知道这个问题怎么产生怎么解决了。不过不用怕,还好小编有一个大绝招,那就是找接口。我找呀找,终于被我找到了,哎,功夫不负苦心人。如图所示:

0788c4952860a6e0fbd9afbc9c306499.png

e8c0968cef944be3b1a38491c8623574.png

6、发现这是个json格式的所以我们现在可以将他进行读取,如图:

fd68ee1da90c05a7a505458d6d93a3dc.png

7、不容易啊,json的坑很多,于是决定用字典。哈哈哈哈,果然适合自己的才是最香的。

找到了这些东西我们就可以把他们提取出来啦,这样我们就提取出了第一页的所有结果,要想提取第二页的结果只需将p的结果改为2即可。

最终的结果,如图:

27cab296657fa29e9042ca46893f8748.png

8、接下来我们强化下程序,让他具有交互功能,供用户选择。

4def9e1c75688800731529737ca147e4.png

9、但是我们了解到callback一般都是可变的函数,所以真正能用上的就只有两个参数,q和p,于是:

1df4bc403a18c780856fd2254fa7d36a.png

这样就完成了指定页面的文件浏览。

下载的话也比较简单,直接将链接复制到浏览器中即可,这样就完成了一个最简单的搜索引擎了。

/5 小结/

1、不建议抓取太多数据,容易对服务器造成负载,浅尝辄止即可。
2、本文基于Python网络爬虫,利用爬虫库,打造了一款简易的Python搜索引擎。
3、实现的时候,总会有各种各样的问题,切勿眼高手低,勤动手,才可以理解的更加深刻。
4如果需要本文源码的话,请在公众号后台回复“Python引擎”关键字进行获取,觉得不错,记得给个star噢。

------------------- End -------------------

往期精彩文章推荐:

  • 手把手用Python教你如何发现隐藏wifi

  • 手把手教你用Python做个可视化的“剪刀石头布”小游戏

  • 一篇文章带你搞懂网络爬虫过程中伪装浏览器的请求头常见字段

2dccaf80f79e7504d1261a7584a1a396.png

欢迎大家点赞,留言,转发,转载,感谢大家的相伴与支持

想加入Python学习群请在后台回复【入群

万水千山总是情,点个【在看】行不行

/今日留言主题/

随便说一两句吧~~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值