如何使用PHP采集大淘客优惠券到网站,同步到WordPress网站

最近在开发一套淘宝客系统软件,在解决各种的问题,导致没有空写文章,看了很多朋友都问这个数据如何导入到数据库里面,那么今天我就以同步大淘客的数据作为例子,讲解一下如何把数据同步到本地数据库中。如果对我这个课程感兴趣的话,可以订阅我的头条号:一点热,也欢迎大家在下方的讨论区讨论。

既然是以大淘客的数据为例子,那么我们需要的就是大淘客的appkey,具体申请地址可以到这里查看

http://www.dataoke.com/ucenter/appkey_apply.asp

那么我们就开始我们要同步的数据了,由于我开始设计的数据库的字段和大淘客返回的数据的字段有一些不一样,那么我们需要对我们的数据库进行改造,改造后的数据库语句如下

DROP TABLE IF EXISTS `yeehot_taobaoke_product`;

CREATE TABLE `yeehot_taobaoke_product` (

`shopid` varchar(255) CHARACTER SET utf8 NOT NULL,

`name` varchar(255) CHARACTER SET utf8 NOT NULL,

`image` varchar(255) CHARACTER SET utf8 NOT NULL,

`detail` varchar(255) CHARACTER SET utf8 NOT NULL,

`type` varchar(255) CHARACTER SET utf8 NOT NULL,

`tbk_link` varchar(255) CHARACTER SET utf8 NOT NULL,

`price` varchar(255) CHARACTER SET utf8 NOT NULL,

`product_sale_count` varchar(255) CHARACTER SET utf8 NOT NULL,

`product_rate` varchar(255) CHARACTER SET utf8 NOT NULL,

`product_earn` varchar(255) CHARACTER SET utf8 NOT NULL,

`wangwang_name` varchar(255) CHARACTER SET utf8 NOT NULL,

`saler_id` varchar(255) CHARACTER SET utf8 NOT NULL,

`shop_name` varchar(255) CHARACTER SET utf8 NOT NULL,

`product_from` varchar(255) CHARACTER SET utf8 NOT NULL,

`card_id` varchar(255) CHARACTER SET utf8 NOT NULL,

`card_num` varchar(255) CHARACTER SET utf8 NOT NULL,

`card_own` varchar(255) CHARACTER SET utf8 NOT NULL,

`card_money` varchar(255) CHARACTER SET utf8 NOT NULL,

`card_begin` varchar(255) CHARACTER SET utf8 NOT NULL,

`card_end` varchar(255) CHARACTER SET utf8 NOT NULL,

`card_link` varchar(255) CHARACTER SET utf8 NOT NULL,

`card_share` varchar(255) CHARACTER SET utf8 NOT NULL,

`short_title` varchar(255) DEFAULT NULL,

`cid` varchar(255) DEFAULT NULL,

`quan_price` varchar(255) DEFAULT NULL,

`dsr` varchar(255) DEFAULT NULL,

`Commission_jihua` varchar(255) DEFAULT NULL,

`Commission_queqiao` varchar(255) DEFAULT NULL,

`Jihua_link` varchar(255) DEFAULT NULL,

`Jihua_shenhe` varchar(255) DEFAULT NULL,

`Introduce` varchar(255) DEFAULT NULL,

`Quan_m_link` varchar(255) DEFAULT NULL,

`Quan_link` varchar(255) DEFAULT NULL,

`id` int(10) unsigned NOT NULL AUTO_INCREMENT,

`Quan_condition` varchar(255) NOT NULL,

`after_price` varchar(255) NOT NULL,

PRIMARY KEY (`id`)

) ENGINE=MyISAM DEFAULT CHARSET=gbk;

SET FOREIGN_KEY_CHECKS = 1;

注意:如果这里不知道怎么操作更新的话,可以重新导入daogou.sql

 

快速开发淘宝客系统-同步大淘客优惠券数据到本地数据库

使用PHP需要访问数据,一般都是使用curl函数来实现的,简单的几个步骤就可以进行get操作了,代码如下:

function getinfo($url) {

$ch = curl_init();

//设置选项,包括URL

curl_setopt($ch, CURLOPT_URL, $url);

curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);

curl_setopt($ch, CURLOPT_HEADER, 0);

//执行并获取HTML文档内容

$output = curl_exec($ch);

//释放curl句柄

curl_close($ch);

return $output;

}

有了这个网络访问链接,那么我们就可以进行数据的采集。

对比大淘客的全站领券商品API接口

http://api.dataoke.com/index.php?r=Port/index&type=total&appkey=”你的APPKEY”&v=2&page=”当前页数”

基本就是两个参数,一个是刚刚我们说到的KEY,还有一个页数。

了解这个接口后,我们就可以开发采集的功能了

采集这里,基本就是解析大淘客的数据,然后查询一下数据库是否有这个商品,如果存在的话,我们就更新它,如果不存在,我们就插入这个数据。具体代码如下:

function SysInfo($page) {

$caijiurl =”http://api.dataoke.com/index.php?r=Port/index&type=total&appkey=”. tk_key .”&v=2&page=”. $page;

$url = $caijiurl;

$info = getinfo($url);

$info = preg_replace(‘/\s/’,”, $info);

$info = str_replace(”,”, $info);

$resultinfo = json_decode($info, TRUE);

$totolnum = $resultinfo[‘data’][‘total_num’];

$page_all = $totolnum / 200 + 1;

$pnum = count($resultinfo[‘result’]);

echo”正在同步第”.$page.”页…<br/>”.”总页数:”.$page_all.”<br/>”;

echo”请稍等,同步需要时间,如果长时间没有响应,返回链接数据库超时,请将参数的page的数字记录下来再同步”;

$nd = array();

for ($i = 0; $i < $pnum; $i++) {

$info = $resultinfo[‘result’][$i];

$nd[$i][‘name’] = $info[‘D_title’];

$nd[$i][‘shopid’] = $info[‘GoodsID’];

$nd[$i][‘image’] = $info[‘Pic’];

$nd[$i][‘detail’] = $info[‘GoodsID’];

$nd[$i][‘short_title’] = $info[‘D_title’];

$nd[$i][‘cid’] = $info[‘Cid’];

$nd[$i][‘Quan_link’] = $info[‘Quan_link’];

$nd[$i][‘Quan_m_link’] = $info[‘Quan_m_link’];

$nd[$i][‘Introduce’] = $info[‘Introduce’];

$nd[$i][‘Jihua_shenhe’] = $info[‘Jihua_shenhe’];

$nd[$i][‘Jihua_link’] = $info[‘Jihua_link’];

$nd[$i][‘Commission_queqiao’] = $info[‘Commission_queqiao’];

$nd[$i][‘Commission_jihua’] = $info[‘Commission_jihua’];

$nd[$i][‘dsr’] = $info[‘Dsr’];

$nd[$i][‘quan_price’] = $info[‘Quan_price’];

$nd[$i][‘card_share’] = $info[‘Quan_m_link’];

$nd[$i][‘card_link’] = $info[‘Quan_link’];

$nd[$i][‘card_begin’] = $info[‘Quan_time’];

$nd[$i][‘card_end’] = $info[‘Quan_time’];

$nd[$i][‘card_money’] = $info[‘Quan_price’];

$nd[$i][‘card_own’] = $info[‘Quan_surplus’];

//$nd[$i][‘card_num’] = $info[‘card_num’];

$nd[$i][‘card_id’] = $info[‘Quan_id’];

$nd[$i][‘Quan_condition’] = $info[‘Quan_condition’];

$nd[$i][‘product_from’] = $info[‘IsTmall’] == 1 ?”天猫”:”淘宝”;

$nd[$i][‘saler_id’] = $info[‘SellerID’];

$nd[$i][‘product_sale_count’] = $info[‘Sales_num’];

$nd[$i][‘price’] = $info[‘Org_Price’];

$nd[$i][‘after_price’] = $info[‘Price’];

$nd[$i][‘product_rate’] = $info[‘Commission_jihua’];

$values =”‘”. implode(“‘,'”, array_values($nd[$i])) .”‘”;

$keys =”`”. implode(“`,`”, array_keys($nd[$i])) .”`”;

$shopid_1 = $nd[$i][‘shopid’];

$query = mysql_query(“select * from yeehot_taobaoke_product where shopid=’$shopid_1′”);

//var_dump(“select * from yeehot_taobaoke_product where shopid='”.$shopid_1.”‘”);

$num = mysql_num_rows($query);

//var_dump($num);

if ($num > 0) {

$sql =’update `yeehot_taobaoke_product` set ‘;

for ($m = 0; $m < count(array_keys($nd[$i])); $m++) {

if($m== (count(array_keys($nd[$i]))-1)){

$sql.=array_keys($nd[$i])[$m].”= ‘”.array_values($nd[$i])[$m].”‘”;

}

else{

$sql.=array_keys($nd[$i])[$m].”= ‘”.array_values($nd[$i])[$m].”‘, “;

}

}

$sql.=” where shopid =”.$shopid_1;

} else {

$sql =’insert into `yeehot_taobaoke_product` ‘;

$sql .='(‘. $keys .’) ‘;

$sql .=’values ‘;

$sql .='(‘. $values .’) ‘;

}

//var_dump($sql);

mysql_query($sql);

}

return $page_all;

}

最好,我们需要调用这个数据,这里,我想调用第一页,然后在根据第一页返回总的页数。然后通过循环更新页数

$page_all=SysInfo(1);

for ($j=1; $j <$page_all ; $j++) {

SysInfo($j);

sleep(5);

}

echo”<br/>同步完成”;

这样,我们的同步商品优惠券的页面就开发完毕了

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Java斌

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值