0

レポートからの配列があります。

このレポートには次のような情報があります。

157479877294,OBSOLETE_ORDER,obelisk,19/01/2013 01:42pm
191532426695,WRONG_PERFORMANCE,g3t1,19/01/2013 01:56pm
159523681637,WRONG_PERFORMANCE,g3t1,19/01/2013 01:57pm
176481653889,WRONG_PERFORMANCE,g4t1,19/01/2013 01:57pm
167479810401,WRONG_PERFORMANCE,g4t1,19/01/2013 02:00pm
172485359309,WRONG_PERFORMANCE,g4t2,19/01/2013 02:02pm
125485358802,WRONG_PERFORMANCE,g4t2,19/01/2013 02:02pm
172485359309,DAY_LIMIT_EXCEEDED,obelisk,19/01/2013 02:03pm
125485358802,DAY_LIMIT_EXCEEDED,obelisk,19/01/2013 02:03pm

私がする必要があるのは、各タイプのエラーと場所の合計を取得することです。そのため、最初のエラーは「OBSOLETE_ORDER」と場所:「オベリスク」になります。私はこれをいくつかの方法でやろうとしましたが、私が思いつくことができる最高のものは多次元配列です:

$error_handle = fopen("$reportUrl", "r");
while (!feof($error_handle) )
   {
      $line_of_text = fgetcsv($error_handle, 1024);
      $errorName = $line_of_text[1];
      $scannerName = $line_of_text[2];
      if($errorName != "SCAN_RESULT" && $errorName != "" && $scannerName != "SCAN_LOGIN" && $scannerName != "")
          {
              $errorsArray["$errorName"]["$scannerName"]++;
          }
   }
fclose($error_handle);
print_r($errorsArray);

私に次を与えます:

Array ( [OBSOLETE_ORDER] => Array ( [obelisk] => 1 ) [WRONG_PERFORMANCE] => Array ( [g3t1] => 2 [g4t1] => 2 [g4t2] => 2 ) [DAY_LIMIT_EXCEEDED] => Array ( [obelisk] => 2 ) )

これは素晴らしいことです...どうすればそれを分解してSQLデータベースに追加できますか?! (配列の下にあるキーの下にあるキーとそのキーの合計を取得することに興味があります)

そしてそれをテーブルに追加します

-errors- (インデックス)id_errors id_event id_access_scanner id_errors_type total_errors

-errors_type- (インデックス)id_errors_type name_errors_type

-access_scanner- (index)id_access_scanner id_ポータル名_access_scanner

助けてください!

ありがとう!

4

4 に答える 4

0

編集した質問では、このはるかに単純なループが機能します。データをエコーアウトするのではなく、ループ内のデータベースに挿入するだけです。

$errorsArray = Array (
        [OBSOLETE_ORDER] => Array (
                                    [obelisk] => 1 
                                )
        [WRONG_PERFORMANCE] => Array (
                                    [g3t1] => 2 
                                    [g4t1] => 2 
                                    [g4t2] => 2 
                                ) 
        [DAY_LIMIT_EXCEEDED] => Array ( 
                                    [obelisk] => 2 
                                ) 
    )

foreach($errorsArray as $row => $errors) {
    foreach($errors as $error => $count) {
        echo $row;  // 'OBSOLETE_ORDER'
        echo $error;    // 'obelisk'
        echo $count;    // 1
        // insert into database here
    }
}

古い答え必要な情報、理想的にはカウントを保持するために必要なのは新しい配列だけです。正しいデータ形式は次のとおりです。

$report = [
  ['157479877294','OBSOLETE_ORDER','obelisk','19/01/2013 01:42pm'],
  ['191532426695','WRONG_PERFORMANCE','g3t1','19/01/2013 01:56pm'],
  ['159523681637','WRONG_PERFORMANCE','g3t1','19/01/2013 01:57pm'],
  ['176481653889','WRONG_PERFORMANCE','g4t1','19/01/2013 01:57pm'],
  .....
];

foreach($report as $array) {
  $errorName = $array[1];
  $scannerName = $array[2];
  if(exists($errorsArray[$errorName][$scannerName])) {
    $errorsArray[$errorName][$scannerName] = $errorsArray[$errorName][$scannerName] + 1;
  }
  else {
    $errorsArray[$errorName][$scannerName] = 1;
  }
}
于 2013-02-21T17:03:34.800 に答える
0
$list = array();
foreach ($lines as $line) {
    $values = explode(',' $line);
    $error = $values[1];
    $scanner = $values[2];
    if (!isset($list[$error])) {
         $list[$error] = array();
    }
    if (!isset($list[$error][$scanner])) {
         $list[$error][$scanner] = 1;
    } else {
         $list[$error][$scanner]++;
    }
}
于 2013-02-21T17:04:18.367 に答える
0

多次元配列は必要以上のものです。取るべきアプローチは$arrayKey、カウントを取得できるようにスキャナー名とエラーを組み合わせた配列キーとして使用する独自の文字列 (私の例では) を作成することです。

//this is the array containing all the report lines, each as an array
$lines_of_text;

//this is going to be our output array
$errorScannerArray = array();

//this variable holds the array key that we're going to generate from each line
$arrayKey = null;

foreach($lines_of_text as $line_of_text)
{
    //the array key is a combination of the scanner name and the error name
    //the tilde is included to attempt to prevent possible (rare) collisions
    $arrayKey = trim($line_of_text[1]).'~'.trim($line_of_text[2]);

    //if the array key exists, increase the count by 1
    //if it doesn't exist, set the count to 1
    if(array_key_exists($arrayKey, $errorScannerArray))
    {
        $errorScannerArray[$arrayKey]++;
    }
    else
    {
        $errorScannerArray[$arrayKey] = 1;
    }
}

//clean up
unset($line_of_text);
unset($arrayKey);
unset($lines_of_text);

//displaying the result
foreach($errorScannerArray as $errorScanner => $count)
{
    //we can explode the string hash to get the separate error and scanner names
    $names = explode('~', $errorScanner);
    $errorName = $names[0];
    $scannerName = $names[1];

    echo 'Scanner '.$scannerName.' experienced error '.$errorName.' '.$count.' times'."\n";
}
于 2013-02-21T16:48:33.717 に答える
0

各結果を確認するために、次のことを行いました。

foreach ($errorsArray as $errorName=>$info)
    {
        foreach ($info as $scannerName=>$total)
            {
                print "$errorName -> $scannerName = $total </br>";
            }
    }

そして今、それをSQLに接続します

于 2013-02-22T00:18:33.343 に答える