在本篇教程中,我会描述如何将一个html网页使用cutycapt转化成png图片。

<a target="_blank"></a>
这是在特定linux发行版上的安装命令。
$ sudo apt-get install cutycapt
$ sudo yum install subversion qt-devel qtwebkit-devel gcc-c++ make
$ svn co svn://svn.code.sf.net/p/cutycapt/code/ cutycapt
$ cd cutycapt/cutycapt
使用文本编辑器打开cutycapt.hpp,并且加入在文件的开头加上下面的两行。
#include
最后,如下编译并安装cutycapt。
$ qmake-qt4
$ make
$ sudo cp cutycapt /usr/local/bin/cutycapt
将一个html页面截图成一个png图片,只要使用下面的格式运行cutycapt。
$ cutycapt --url=http://www.cnn.com --out=cnn.png
要将html页面保存成不同的格式(比如,pdf),只要适当地指定输出文件。
$ cutycapt --url=http://www.cnn.com --out=cnn.pdf
下图显示了cutycapt命令选项。
虽然cutycapt是一个命令行工具,但是它需要x服务运行。如果你尝试在不含x服务的机器上运行,你会得到下面这个错误:
cutycapt: cannot connect to x server :0
如果你要不含x的服务器上运行cutycapt,你可以在服务器上安装xvfb(轻量级“假的”x11 服务)。这样cutycapt就不会报错了。
要在debian, ubuntu 或者 linux mint 上安装xvfb:
$ sudo apt-get install xvfb
要在fedora, centos 或者 rhel 上安装xvfb:
$ sudo yum install xvfb
在安装xvfb之后,接下来像这样运行cutycapt。
$ xvfb-run --server-args="-screen 0, 1280x1200x24" cutycapt --url=http://www.cnn.com --out=cnn.png
它首先会运行xbfb服务,接着使用cutycapt来抓取网页。因此它可能会花费更长的时间。如果你想要截图多张截图,你可能事先需要将xvfb作为后台守护进程启动。
原文发布时间为:2014-03-18
本文来自云栖社区合作伙伴“linux中国”