PHP 如何将进口商字段映射到 csv 第一行字段?
PHP how to map importer fields to csv first row fields?
我正在将 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: EAN on $EANColumn = str_replace('’', '', $importData_arr["EAN"]);
重点是提供一种简单的方法,通过 csv 将供应商的数据导入 mysql。然后将其显示到网上商店网站。
这里有一些简单的建议,如何将您的数据映射到具有给定键的数组。
while ($row = fgetcsv($fp, 100, ',')) {
$columnName = ['a','b','c','d','e','f'];
$myRow = array_combine($columnName,$row);
....
在 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'];
}
只要字段名称保持不变,您就不必在字段顺序或计数发生变化时更改导入代码。
我正在将 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: EAN on $EANColumn = str_replace('’', '', $importData_arr["EAN"]);
重点是提供一种简单的方法,通过 csv 将供应商的数据导入 mysql。然后将其显示到网上商店网站。
这里有一些简单的建议,如何将您的数据映射到具有给定键的数组。
while ($row = fgetcsv($fp, 100, ',')) {
$columnName = ['a','b','c','d','e','f'];
$myRow = array_combine($columnName,$row);
....
在 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'];
}
只要字段名称保持不变,您就不必在字段顺序或计数发生变化时更改导入代码。