我找到了该网站http://itsolutionstuff.com/post/laravel-56-import-export-to-excel-and-csv-exampleexample.html的代码
这是我编辑后的路线:
Route::post('barang', 'BarangController@importExcel')->name('barang');
这是他们的控制器,我只是添加了foreach:
public function importExcel(Request $request)
{
$request->validate([
'import_file' => 'required'
]);
$path = $request->file('import_file')->getRealPath();
$data = Excel::load($path)->get();
if($data->count()){
foreach ($data as $key => $value) {
$arr[] = [
'kode_barang' => $value->kode_barang,
'nama_barang' => $value->nama_barang,
'kategori_id' => $value->kategori_id,
'jumlah_barang' => $value->jumlah_barang,
'harga_satuan' => $value->harga_satuan,
'tanggal_inputan' => $value->tanggal_inputan,
'deskripsi' => $value->deskripsi,
'status' => $value->status,
];
}
if(!empty($arr)){
Item::insert($arr);
}
}
return back()->with('success', 'Insert Record successfully.');
}
然后我将其添加到我的视图中:
<form action="{{ route('barang') }}" class="form-horizontal" method="post"
enctype="multipart/form-data">
@csrf
@if ($errors->any())
<div class="alert alert-danger">
<a href="#" class="close" data-dismiss="alert"
aria-label="close">×</a>
<ul>
@foreach ($errors->all() as $error)
<li>{{ $error }}</li>
@endforeach
</ul>
</div>
@endif
@if (Session::has('success'))
<div class="alert alert-success">
<a href="#" class="close" data-dismiss="alert"
aria-label="close">×</a>
<p>{{ Session::get('success') }}</p>
</div>
@endif
<input type="file" name="import_file" />
<button class="btn btn-primary">Import File</button>
</form>
结果显示数据已成功插入,但没有数据插入到我的表中。
这是我的excel CSV格式:
R4B6,MONITOR LENOVO,ELEKTRONIK,1,-,10/4/2018,-,Aktif
那么,如何使代码正确插入数据库?
答案 0 :(得分:0)
无需使用任何第三方库,您可以使用以下功能从表中下载Excel文件。
protected function downloadEXCEL(Request $request){
$table = User::orderBy('created_at','desc')->get();
$filename = "output.xls";
$handle = fopen($filename, 'w+');
fputcsv($handle,array('user_email','mobile','country','state','address','zip_code','city'));
foreach($table as $row) {
fputcsv($handle,array(
$row['user_email'],
$row['mobile'],
$row['country'],
$row['state'],
$row['address'],
$row['zip_code'],
$row['city']
));
}
fclose($handle);
$headers = array('Content-type'=> 'application/vnd.ms-excel');
return response()->download($filename,'output.xls',$headers);
}
答案 1 :(得分:0)
首先请更改您的代码,如下所示:
if($data->count()){
foreach ($data as $key => $value) {
$arr[] = [
'kode_barang' => $value->kode_barang,
'nama_barang' => $value->nama_barang,
'kategori_id' => $value->kategori_id,
'jumlah_barang' => $value->jumlah_barang,
'harga_satuan' => $value->harga_satuan,
'tanggal_inputan' => $value->tanggal_inputan,
'deskripsi' => $value->deskripsi,
'status' => $value->status
];
}
if(!empty($arr)){
Item::insert($arr);
return back()->with('success', 'Insert Record successfully.');
}else{
return back()->with('error', 'Failed to insert record.');
}
}
然后尝试调试代码,为什么不插入记录。