我創建了一個從 CSV ( http://liamjken.com/aim-parse/aim-websites-new.csv ) 獲取資料的頁面,并將其顯示在此頁面上http://www.liamjken.com/aim -parse/parse.php?17
?17 參考 csv 檔案中的行。因此,如果我將其更改為 ?10,它會從不同的行中提取資訊。
我想做而不是使用行號是使用 $vin_num 值。因此,如果我將 ?1FMCU9GD9KUC40413 放在 URL 的末尾,它將顯示包含該數字的行。
這是我目前擁有的代碼,它基本上是由我發現的多種不同趨勢拼湊而成的,因此如果您發現其他潛在問題,我很高興聽到它們。
<?php
$qstring = $_SERVER['QUERY_STRING'];
$row = $qstring; // The row that will be returned.
$data = get_row('aim-websites-new.csv', $row);
'<pre>'.print_r($data).'</pre>';
function get_row($csv, $row) {
$handle = fopen("$csv", 'r');
$counter = 0;
$result = '';
while ( ($data = fgetcsv($handle)) !== FALSE ) {
$counter ;
if ( $row == $counter ) {
$vin_num="$data[12]";
$model="$data[10]";
$make="$data[9]";
$year="$data[8]";
ob_start();
?>
<h1>VIN: <?php echo $vin_num; ?></h1>
<h1>Year: <?php echo $year; ?></h1>
<h1>Make: <?php echo $make; ?></h1>
<h1>Model: <?php echo $model; ?></h1>
<?php
$output = ob_get_clean();
ob_flush();
return $output;
}
}
}
?>
uj5u.com熱心網友回復:
<?php
function extract_data($file)
{
$raw = file($file); // file() puts each line of file as string in array
$keys = str_getcsv(array_shift($raw)); // extract the first line and convert into an array
// Look through the rest of the lines and combine them with the header
$data = [];
foreach ($raw as $line) {
$row = str_getcsv($line);
$data[] = array_combine($keys, $row);
}
return $data;
}
function get_record($data, $vin)
{
foreach ($data as $record) {
if ($record['VIN'] === $vin)
return $record;
}
return null;
}
$data = extract_data('aim-websites-new.csv');
$vin = $_SERVER['QUERY_STRING'];
if (empty($vin)) {
echo '<h1>No VIN provided</h1>';
exit;
}
$record = get_record($data, $vin);
if ($record === null) {
echo '<h1>No record found</h1>';
exit;
}
echo '<h1>' . $record['VIN'] . '</h1>';
echo '<h1>' . $record['Year'] . '</h1>';
echo '<h1>' . $record['Make'] . '</h1>';
echo '<h1>' . $record['Model'] . '</h1>';
echo '<pre>' . print_r($record, true) . '</pre>';
如果您不相信這些記錄將具有有效的 VIN,您可以使用此處發布的代碼進行驗證:如何驗證 VIN 號碼?
轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/324855.html
