<a href="#%E5%89%8D%E8%A8%80">前言</a>
<a href="#%E5%B7%A5%E5%85%B7%E5%88%97%E8%A1%A8">工具列表</a>
<a href="#supervisor">supervisor</a>
<a href="#%E5%AE%89%E8%A3%85">安装</a>
<a href="#%E4%BD%BF%E7%94%A8">使用</a>
<a href="#node-inspector">node-inspector</a>
<a href="#%E5%AE%89%E8%A3%85-1">安装</a>
<a href="#%E4%BD%BF%E7%94%A8-1">使用</a>
<a href="#superagent">SuperAgent</a>
<a href="#%E5%AE%89%E8%A3%85-2">安装</a>
<a href="#%E4%BD%BF%E7%94%A8-2">使用</a>
<a href="#%E6%95%99%E7%A8%8B">教程</a>
<a href="#cheerio">cheerio</a>
<a href="#%E5%AE%89%E8%A3%85-3">安装</a>
<a href="#%E4%BD%BF%E7%94%A8-3">使用</a>
<a href="#%E6%95%99%E7%A8%8B-1">教程</a>
<a href="#%E6%80%BB%E7%BB%93">总结</a>
学了Nodejs一天了,这种异步非阻塞式的编程模型仿佛一下子打破了我的思维模式,总有一种根本不会编程的感觉。不过从中也确实让我获得了很多宝贵的经验。
这里暂且记录一下学习过程中遇到的一些实用的库吧,给自己一个纪念。
之前写Python的Flask或者Django的时候,一旦修改了源代码,后台调试服务器就会自动检测到变化,然后restart。所以可以直接在浏览器上直接刷新看到最新的结果。而写了一点点Node代码的我发现每次都必须先CTRL+C,然后重新运行服务器端代码,才能看到最新的结果。
Nodejs只有在第一次引用到某部分时才回去解析脚本,以后都会直接访问内存中解析好的脚本文件内容。
这在一定程度上确实提高了性能,但是开发的时候真的不是一个好做法。幸好supervisor就是专门用来解决这个问题的。
其实就是对node的一个包装。比如我写了一个简单的服务器程序sample.js。
正常运行的话是
但是这样不能实时检测到脚本文件的变化,这时就可以让supervisor出场了。
命令本身也会给我们很多提示性的内容。
不难看出,supervisor启动了一个子进程来处理node脚本,然后本身检测文件变化,实时做处理。
rs命令代表着restarting,即我们可以手动的让服务器脚本重新启动。
调试代码的一款比较好用的在线调试工具。用户界面看起来还算不错。
首先要链接待调试文件。
其中xxx.js就是你要调试的出错的node文件。
接下来就是启动。
查看和操作
这时打开浏览器,输入
即可通过漂亮的UI来执行调试命令了。
如下图:
需要注意的是:node-inspector内部依赖于webkit,所以只能在以webkit为内核的浏览器上运行。
类似于Python中的requests, 在Nodejs中也有这么一个很好用的网络请求库,那就是SuperAgent。下面简单的来测试一下。
我这边直接按照自己的理解,写了一个post请求方式,来获取图灵机器人接口内容的示例。代码如下:
运行代码获得的信息如下:
本来我想自己写一遍这些基础的用法的,但是看到了官网的简介,甚是简洁,逻辑清晰,示例优雅。然后我觉得没必要重复造轮子了,下面两个链接看完之后基本上就能熟练掌握了。
谈到了SuperAgent类似于Python中的requests, 那么在获取到网页内容之后,解析内容的话,在Python中有BeautifulSoup这么个神器,那么在Nodejs中呢?
答案是cheerio。功能上类似于BeautifulSoup,可以作为一款优秀的解析器来使用。
没有一个例子的话,感觉不怎么像回事。下面还是来个简单的例子。
执行如下命令
即可看到如下内容。
为了避免重复造轮子, 我还是把看到的很经典的链接放过来吧。相信中英文结合着看,运用BeautifulSoup 和JQuery的思维模式,对于cheerio 就不在话下了。
到目前为止,对于简单的数据抓取掌握了这几个库就不成问题了。然而实际上,这还远远不够。对于这个工具列表,有时间的话,再回来更新吧。