gpt4 book ai didi

PHP 如何将进口商字段映射到 csv 第一行字段?

转载 作者:行者123 更新时间:2023-12-04 17:23:28 24 4
gpt4 key购买 nike

我正在将 rims 从 csv 文件导入到网上商店项目。没有什么可卖的,只是一个学习进口商如何工作的个人项目。我正在尝试将我的 $EANColumn 变量映射到我的 csv 中的第一行字段名称。

所以目前我有一个包含以下字段的 csv:

EAN;品牌;...以及更多内容


1234-WB;WheelBrand...以及更多内容


5678-BW;BrandWheel...以及更多内容


目前在我的导入器中,它在我映射时工作:

$EANColumn     = str_replace('’', '', $importData_arr["EAN"]);

并通过数组将其插入到我的数据库中:

foreach($importData_arr as $importData){
// var_dump($importData);
$insertData = array(
"EAN" =>$EANColumn);
RimsUpload::insertData($insertData);

这部分的完整代码在这里:

if ($request->input('submit') != null ){

$file = $request->file('file');

// File Details
$filename = $file->getClientOriginalName();
$extension = $file->getClientOriginalExtension();
$tempPath = $file->getRealPath();
$fileSize = $file->getSize();
$mimeType = $file->getMimeType();

// Valid File Extensions
$valid_extension = array("csv");

// 2MB in Bytes
$maxFileSize = 2097152;

// Check file extension
if(in_array(strtolower($extension),$valid_extension)){

// Check file size
if($fileSize <= $maxFileSize){

// File upload location
$location = 'uploads';

// Upload file
$file->move($location,$filename);

// Import CSV to Database
$filepath = url($location."/".$filename);

// Reading file
$file = fopen($filepath,"r");

$importData_arr = array();
$i = 0;

while (($filedata = fgetcsv($file, 1000, ";")) !== FALSE) {
$num = count($filedata );

$EANColumn = str_replace('’', '', $importData_arr["EAN"]);
$BrandColumn = $importData_arr["Brand"];

// Skip first row (Remove below comment if you want to skip the first row)
if($i == 0){
$i++;
continue;
}

for ($c=0; $c < $num; $c++) {
$importData_arr[$i][] = $filedata [$c];
}
$i++;
}
fclose($file);

dump($importData_arr);
// Insert to MySQL database
foreach($importData_arr as $importData){
// var_dump($importData);
$insertData = array(
"EAN" =>$EANColumn,
"Brand"=>$BrandColumn,
"Name"=>$importData[2],
"Size"=>$importData[3],
"PCD"=>$importData[4],
"Offset"=>$importData[5],
"Bore"=>$importData[6],
"Color"=>$importData[7],
"Price"=>$importData[8],
"Stock"=>$importData[9],
"ImageURL"=>$importData[10]);
RimsUpload::insertData($insertData);

}

Session::flash('message','Import Successful.');
}else{
Session::flash('message','File too large. File must be less than 2MB.');
}

}else{
Session::flash('message','Invalid File Extension.');
}

}

// Redirect to index
// return redirect()->action("RimsUploadController@index", [$request]);
return response()->redirectToAction('App\Http\Controllers\RimsUploadController@index', [$request]);
}

但真正的问题是我不想将我的列映射为 [0]、[1]、[2]、[3]...我想从第一行列名称中取出它们:["EAN"]、["Brand"]、["Name"]、["Size"]...因此,如果 EAN 是第 1 列或第 7 列,它不会有什么不同,因为它将通过名称而不是行号来检测它。因此它将能够处理具有不同列顺序的文件。

尝试执行此操作时,出现错误: undefined index :$EANColumn 上的 EAN = str_replace(''', '', $importData_arr["EAN"]);

重点是提供一种简单的方法,通过 csv 将供应商的数据导入 mysql。然后将其显示到网上商店网站。

最佳答案

在 while 循环之前,从 csv 的第一行中提取字段名称:

$file = fopen($filepath,"r");
$keys = fgetcsv($file, 1000, ';');

然后,获取数据行并将 $keys 数组与数据组合成一个关联数组:

$importData_arr = [];
while ($line = fgetcsv($file, 1000, ';')) {
$data = array_combine($keys, $line);
// Do something with the data
$data['EAN'] = str_replace('’', '', $data['EAN']);
$importData_arr[] = $data;
}
fclose($file);

您现在可以通过名称访问所有数据字段,与 CSV 中的顺序无关:

foreach($importData_arr as $importData){
echo $importData['EAN'];
}

只要字段名称保持不变,您就不必在字段顺序或计数发生变化时更改导入代码。

关于PHP 如何将进口商字段映射到 csv 第一行字段?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64912682/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com