在框架中使用

QueryList无框架依赖,可以灵活的嵌入到任何项目中去。


以TinkPHP3.2.3为例,进行讲解。

方法一:通过composer自动安装

直接在ThinkPHP根目录执行命令:

  1. composer require jaeger/querylist

就安装好了QueryList了,然后在index.php中引入composer的自动加载文件:

  1. <?php
  2. // 应用入口文件
  3. //........
  4. //加上下面这一句话,用于自动加载QueryList
  5. require 'vendor/autoload.php';
  6. // 引入ThinkPHP入口文件
  7. require './ThinkPHP/ThinkPHP.php';
  8. // 亲^_^ 后面不需要任何代码了 就是如此简单

只需这两步就可以在你的框架中任意使用QueryList了:

  1. <?php
  2. namespace Home\Controller;
  3. use Think\Controller;
  4. use QL\QueryList;
  5. class IndexController extends Controller {
  6. public function index(){
  7. //采集某页面所有的图片
  8. $data = QueryList::Query('http://cms.querylist.cc/bizhi/453.html',['image' => ['img','src']])->data;
  9. //打印结果
  10. print_r($data);
  11. }
  12. }

方法二:手动安装

1.下载

QueryList下载地址:https://github.com/jae-jae/QueryList/tree/V3.2.1

phpQuery下载地址:https://github.com/jae-jae/phpQuery-single

2.安装

根据TP官方教程:http://document.thinkphp.cn/manual_3_2.html#lib_extend

假设你的网站根目录为 www

先列出安装好后的目录结构:

  1. www
  2. └── ThinkPHP
  3. ├── Library
  4. ├── QL
  5. ├── phpQuery.php
  6. └── QueryList.class.php

安装过程:

  1. 1.下载`QueryList.php``phpQuery.php`这两个文件。
  2. 2.` www/ThinkPHP/Library`下新建`QL`目录。
  3. 3.将下载好的`QueryList.php``phpQuery.php`这两个文件复制到` www/ThinkPHP/Library/QL`目录。
  4. 4.重命名`QueryList.php``QueryList.class.php`

然后就可以在你的框架中任意使用QueryList了,但是运行你会发现提示没有找到phpQuery,此时有两个解决方案:

方案一:在每次使用QueryList之前手动引入phpQuery

方案二:修改QueryList源码,加上下面这句话:

  1. require 'phpQuery.php';

这样就不用每次手动引入phpQuery

3.用例

  1. <?php
  2. namespace Home\Controller;
  3. use Think\Controller;
  4. use QL\QueryList;
  5. class IndexController extends Controller {
  6. public function index(){
  7. //采集某页面所有的超链接
  8. $data = QueryList::Query('http://cms.querylist.cc/bizhi/453.html',['link' => ['a','href']])->data;
  9. //打印结果
  10. print_r($data);
  11. }
  12. }

4.附上ThinkPHP手动安装好QueryList的压缩包

看完教程依旧不懂的话,可以下载我打包好的压缩包,解压看看:下载地址:http://source.querylist.cc/Querylist-demo/thinkphp3.2.3_QueryList3_custom.zip