вставка в mysql массив значений - PullRequest
0 голосов
/ 28 февраля 2012

это отредактированный код, в котором г-н.Paulo Rodrigues, php curl используется для получения записей или данных на указанной веб-странице.это сохранит в файле .txt.Откройте файл, затем получите данные каждой записи, затем выполните цикл для вставки всех данных, требуемых в записях.

$ch = curl_init("http://www.uniprot.org/uniprot/?query=(annotation%3a(type%3asignal+confidence%3aexperimental))+AND+reviewed%3ayes&sort=score&limit=10&format=txt");
$fp = fopen("file.txt", "w");

curl_setopt($ch, CURLOPT_FILE, $fp);
curl_setopt($ch, CURLOPT_HEADER, 0);

curl_exec($ch);


while (!feof($fp))
{

$array = array();
$index = -1;

foreach ($fp as $line) {
if (preg_match('#^ID#', $line)) {
    $index++;
}

$array[$index][] = $line;
}

foreach ($array as $block) {
$fields = array();

foreach ($block as $item) {
    if (preg_match('#^ID\s+(.*?)\s#', $item, $matches)) {
        print_r($fields['prot_name'] = $matches[1]);
        echo "&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp";
    } 
   else if (preg_match('#^OC\s+(Eukaryota)#', $item, $matches)) {
       print_r($fields['tax_lin'] = $matches[1]);
         echo "&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp
             &nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp";
    } 
    else if (preg_match('#LOCATION:\sMembrane;\s(.*?)\s#', $item, $matches)) {
        print_r($fields['sub_loc'] = $matches[1]); 

    } 

    }

    echo "<br />";

    if (!empty($fields)) {
    $f = implode(', ', array_keys($fields));
    $v = "'" . implode("', '", $fields) . "'";

    $sql = "INSERT INTO swissprot ($f) VALUES($v)";
    mysql_query($sql) or die(mysql_error());
    }


   }
 }

curl_close($ch);
fclose($fp);

проблема в том, что есть предупреждение, которое отображает: «Предупреждение: неверный аргументпредоставляется для foreach () в этой строке. в чем может быть проблема?

foreach ($fp as $line) {
if (preg_match('#^ID#', $line)) {
    $index++;
}

$array[$index][] = $line;
}

1 Ответ

0 голосов
/ 28 февраля 2012

Вы можете попробовать это:

$webpagedata = file('http://www.uniprot.org/uniprot/?query=annotation%3a%28type%3asignal+confidence%3aexperimental%29+reviewed%3ayes&sort=score&limit=10&format=txt');

$array = array();
$index = -1;

foreach ($webpagedata as $line) {
    if (preg_match('#^ID#', $line)) {
        $index++;
    }

    $array[$index][] = $line;
}

foreach ($array as $block) {
    $fields = array();

    foreach ($block as $item) {
        if (preg_match('#^ID\s+(.*?)\s#', $item, $matches)) {
            $fields['prot_name'] = $matches[1];
        } else if (preg_match('#^OC\s+(Eukaryota)#', $item, $matches)) {
            $fields['tax_lin'] = $matches[1];
        } else if (preg_match('#LOCATION:\sMembrane;\s(Single-pass)#', $item, $matches)) {
            $fields['sub_loc'] = $matches[1];
        }
    }

    if (!empty($fields)) {
        $f = implode(', ', array_keys($fields));
        $v = "'" . implode("', '", $fields) . "'";

        $sql = "INSERT INTO spdb ($f) VALUES($v)";
        mysql_query($sql) or die(mysql_error());
    }
}

Обновление:

$ch = curl_init("http://www.uniprot.org/uniprot/?query=(annotation%3a(type%3asignal+confidence%3aexperimental))+AND+reviewed%3ayes&sort=score&limit=10&format=txt");
$fp = fopen("file.txt", "w");

curl_setopt($ch, CURLOPT_FILE, $fp);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_exec($ch);
curl_close($ch);
fclose($fp);

$file = file("file.txt");
$array = array();
$index = -1;

foreach ($file as $line) {
    if (preg_match('#^ID#', $line)) {
        $index++;
    }

    $array[$index][] = $line;
}

foreach ($array as $block) {
    $fields = array();

    foreach ($block as $item) {
        if (preg_match('#^ID\s+(.*?)\s#', $item, $matches)) {
            print_r($fields['prot_name'] = $matches[1]);
            echo "&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp";
        } else if (preg_match('#^OC\s+(Eukaryota)#', $item, $matches)) {
            print_r($fields['tax_lin'] = $matches[1]);
            echo "&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp
             &nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp";
        } else if (preg_match('#LOCATION:\sMembrane;\s(.*?)\s#', $item, $matches)) {
            print_r($fields['sub_loc'] = $matches[1]);
        }
    }

    echo "<br />";

    if (!empty($fields)) {
        $f = implode(', ', array_keys($fields));
        $v = "'" . implode("', '", $fields) . "'";

        $sql = "INSERT INTO swissprot ($f) VALUES($v)";
        mysql_query($sql) or die(mysql_error());
    }
}
...