Laravel excel 验证两列的组合不重复
Laravel excel validate two columns' combination is not duplicate
我有一个要求,我需要确保 Excel 用户上传的文件没有重复的行 w.r.t。 2 个特定的列。
示例:
在下面的代码片段中,我想指出第 1 行和第 2 行包含 COMPANY_CODE
和 CLERK_CODE
的重复组合:
如果发现这样的重复组合,我想拒绝导入整个文件并让用户知道问题出在哪里。
有什么线索吗?
不确定 Maat/Laravel Excel 是否可以轻松解决此问题。因此,我继续创建了关联数组,其中键作为两列的串联,我不想在 Excel.
中重复
然后我使用 foreach 循环手动检查,如果关联数组中存在键,则意味着 Excel 中存在重复条目。
以下示例代码供参考:
$array = Excel::toArray(new MyExcelImport(), request()->file);
$assoc_array = array();
foreach ($array[0] as $key => $value) {
$new_key = $value['company_code'] . $value['clerk_code'];
// Presence of combination of company_code and clerk_code in the assoc_array indicates that
// there is duplicate entry in the Excel being imported. So, abort the process and report this to user.
if (array_key_exists($new_key, $assoc_array)) {
return response()->json("Combination of company_code: " .
$value['company_code'] .
" and clerk_code: " .
$value['clerk_code'] .
" is duplicate in the file being imported. Please correct same and retry upload.", 422);
}
$assoc_array[$new_key] = $value;
}
希望这对有类似需求的人有所帮助!
我有一个要求,我需要确保 Excel 用户上传的文件没有重复的行 w.r.t。 2 个特定的列。
示例:
在下面的代码片段中,我想指出第 1 行和第 2 行包含 COMPANY_CODE
和 CLERK_CODE
的重复组合:
如果发现这样的重复组合,我想拒绝导入整个文件并让用户知道问题出在哪里。
有什么线索吗?
不确定 Maat/Laravel Excel 是否可以轻松解决此问题。因此,我继续创建了关联数组,其中键作为两列的串联,我不想在 Excel.
中重复然后我使用 foreach 循环手动检查,如果关联数组中存在键,则意味着 Excel 中存在重复条目。
以下示例代码供参考:
$array = Excel::toArray(new MyExcelImport(), request()->file);
$assoc_array = array();
foreach ($array[0] as $key => $value) {
$new_key = $value['company_code'] . $value['clerk_code'];
// Presence of combination of company_code and clerk_code in the assoc_array indicates that
// there is duplicate entry in the Excel being imported. So, abort the process and report this to user.
if (array_key_exists($new_key, $assoc_array)) {
return response()->json("Combination of company_code: " .
$value['company_code'] .
" and clerk_code: " .
$value['clerk_code'] .
" is duplicate in the file being imported. Please correct same and retry upload.", 422);
}
$assoc_array[$new_key] = $value;
}
希望这对有类似需求的人有所帮助!