0

我有以下问题。我正在解析具有多个页面的 xml 提要,并且无法了解它们有多少(我在 xml url 中设置了一个变量,因此对于每个变量都有随机数量的页面)。我所知道的是这个数字不能超过 50。现在我有一个脚本,可以自动增加从 1 到 50 的页码变量。

假设该链接共有 26 页。使用我的脚本,我将继续发送请求,直到脚本到达第 50 页。然后它会更改第一个变量并从 1 重新开始到 50。对于第一个链接,从第 27 页开始,xml 将返回以下内容:

<response>
    <status>error</status>
    <code>400</code>
    <message>Incorrect Request Headers</message>
</response>

当 scipt 收到此消息时,我该如何做到这一点,以停止自动增量并通过更改第一个变量继续并从 1 重新开始?现在的代码是:

$query = "SELECT * FROM table_name ORDER BY id ASC";
$result = mysql_query($query) or die(mysql_error()); 
while ($row = mysql_fetch_array($result)) {
    if($row['row_name'] == '') {
        $variable1 = 0;
    }
    else {
        $variable1 = $row['row_name'];
    }

$page = 0;
    do {
        $page++;
        $result = apiCall('option1', 'option2', array('option3' => $variable1, 'page' => $page));
        usleep(1000);
        $res = json_decode($result);
            foreach ($res->node1->node2 as $item) {

            //define variable for insertion in MySQL

            $sql1 to insert the variables
            if (!mysql_query($sql1,$con1))
            {
                die('Error: ' . mysql_error());
            }
        }
    }
    while ($page<=50);
}

在上面的代码中,只有$variable1and$page是变量。所有选项(1、2 和 3)都是预定义的并且保持不变。即,当脚本收到错误消息时,我需要从 1 重新开始,下一个值为$variable1.

4

1 回答 1

0

好的。这是我玩过的代码:

$query = "SELECT * FROM table_name ORDER BY id ASC";
$result = mysql_query($query) or die(mysql_error()); 
while ($row = mysql_fetch_array($result)) {
    if($row['row_name'] == '') {
        $variable1 = 0;
    }
    else {
        $variable1 = $row['row_name'];
    }

$page = 1;
    do {
        $result = apiCall('option1', 'option2', array('option3' => $variable1, 'page' => $page));
        usleep(1000);
        $res = json_decode($result);
    if ($res->status == 'error') {
            break 2;
        }
            foreach ($res->node1->node2 as $item) {

            //define variable for insertion in MySQL

            $sql1 to insert the variables
            if (!mysql_query($sql1,$con1))
            {
                die('Error: ' . mysql_error());
            }
        }
        $page++;
    }
    while (0);
}

问题是它会在某个时候停止脚本执行。无法理解为什么。

于 2012-09-14T19:00:08.483 回答