Я работаю над Yii2
.Я импортирую файл Excel.При импорте я также отправляю id
предыдущей модели.Процесс ниже
- Пользователь открывает графический интерфейс и выбирает некоторые значения из выпадающего списка, а затем нажимает кнопку «Создать».
Создать контроллер
public function actionCreate()
{
$model = new MeterAcceptanceHeader();
$model->prepared_by = Yii::$app->user->id;
$model->prepared_at = date('Y-m-d H:i:s');
if ($model->load(Yii::$app->request->post()) && $model->save()) {
return $this->redirect(['excel','id'=>$model->id]);
} else {
return $this->render('create', [
'model' => $model,
]);
}
}
После нажатия на следующую кнопку пользователю будет предложено новое окно, в котором ему предлагается загрузить файл Excel.
Контроллер Excel
public function actionExcel($id){
$file_name = "excel_" . Yii::$app->user->id . ".xlsx";
$error = "";
if(isset($_FILES['file'])) {
$path_parts = pathinfo($_FILES["file"]["name"]);
$extension = $path_parts['extension'];
if(!in_array($extension,['xlsx','xls'])){
$error = "Invalid file";
}else {
if (move_uploaded_file($_FILES['file']['tmp_name'], 'uploads/' . $file_name)) {
$this->redirect([
'process',
'file_name' => $file_name,
'header_no' => $_POST['header_no'],
'id'=>$id
]);
}
}
}
return $this->render("excel",['error'=>$error,'id'=>$id]);
}
Excel View
<div class="box-body">
<?php if($error != ""){?>
<div class="alert alert-danger"><?=$error?></div>
<?php } ?>
<form action="" method="post" enctype="multipart/form-data">
<input type="hidden" name="_csrf" value="<?= Yii::$app->request->getCsrfToken() ?>"/>
<input id="btn" class="form-control" type="file" name="file" />
<div class="form-group">
<br />
Header Row <br />
<select name="header_no" class="form-control">
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
<option value="4">4</option>
<option value="5">5</option>
<option value="6">6</option>
<option value="7">7</option>
<option value="8">8</option>
</select>
<br />
<input type="submit" value=" Next " class="btn btn-primary" />
</div>
</form>
</div>
После загрузки файла Excel пользователь нажимает следующую кнопку
Теперь напользователю этого окна будет предложено сопоставить поля Excel с полем БД
Process Controller
public function actionProcess(){
$file_name = $_GET['file_name'];
$id = $_GET['id'];
try {
$header_index = $_GET['header_no'];
$data = \moonland\phpexcel\Excel::widget([
'mode' => 'import',
'fileName' => 'uploads/' . $file_name,
'setFirstRecordAsKeys' => false, // if you want to set the keys of record column with first record, if it not set, the header with use the alphabet column on excel.
'setIndexSheetByName' => false, // set this if your excel data with multiple worksheet, the index of array will be set with the sheet name. If this not set, the index will use numeric.
'getOnlySheet' => 0, // you can set this property if you want to get the specified sheet from the excel data with multiple worksheet.
]);
if (isset($data[0])) {
$headers = $data[0][$header_index];
} else {
$headers = $data[$header_index];
}
}catch (Exception $x){
print_r($x->errorInfo);
}
return $this->render('excel_options',['headers'=>$headers,'file_name'=>$file_name,'header_index'=>$header_index,'id'=>$id]);
}
Просмотр параметров Excel
<form action="import" method="post">
<input type="hidden" name="file_name" value="<?=$_GET['file_name']?>" />
<input type="hidden" name="header_index" value="<?= $_GET['header_no'] ?>"/>
<input type="hidden" name="model_id" value="<?= $_GET['id'] ?>"/>
<h1>Maping</h1>
<div class="row">
<div class="col-md-2">
Ref #:
</div>
<div class="col-md-4">
<label>
<select name="field[0][ref_no]" class="form-control">
<option value="">Select A field</option>
<?php foreach($headers as $k=>$v) { ?>
<?php if (trim($v) != '') { ?>
<option value="<?=$k?>"><?=$v?></option>
<?php } ?>
<?php } ?>
</select>
</label>
</div>
</div>
<div class="row">
<div class="col-md-2">
Meter MSN:
</div>
<div class="col-md-4">
<label>
<select name="field[0][meter_msn]" class="form-control">
<option value="">Select A field</option>
<?php foreach ($headers as $k => $v) { ?>
<?php if (trim($v) != '') { ?>
<option value="<?= $k ?>"><?= $v ?></option>
<?php } ?>
<?php } ?>
</select>
</label>
</div>
</div>
<div class="row">
<div class="col-md-2">
Meter Type:
</div>
<div class="col-md-4">
<label>
<select name="field[0][meter_type]" class="form-control">
<option value="">Select A field</option>
<?php foreach ($headers as $k => $v) { ?>
<?php if (trim($v) != '') { ?>
<option value="<?= $k ?>"><?= $v ?></option>
<?php } ?>
<?php } ?>
</select>
</label>
</div>
</div>
<div class="row">
<div class="col-md-2">
Sub-Div:
</div>
<div class="col-md-4">
<label>
<select name="field[0][sub_div]" class="form-control">
<option value="">Select A field</option>
<?php foreach ($headers as $k => $v) { ?>
<?php if (trim($v) != '') { ?>
<option value="<?= $k ?>"><?= $v ?></option>
<?php } ?>
<?php } ?>
</select>
</label>
</div>
</div>
<div class="row">
<div class="col-md-2"></div>
<div class="col-md-4">
<br />
<input type="submit" class="btn btn-primary pull-left" />
</div>
</div>
</form>
Вышеуказанное представление вызывается в process
action controller.И в этом виде я передаю идентификатор модели как скрытое поле.
После сопоставления файла и нажатия на кнопку отправки данные в файле будут сохранены в базе данных.Ниже приведено действие импорта, которое сохранит данные в базе данных
public function actionImport()
{
$file_name = $_POST['file_name'];
$header_index = $_POST['header_index'];
$fieldSet = $_POST['field'];
$model_id = $_POST['model_id'];
print_r($model_id);
die();
.
.
.
return $this->render('excel_finish', ['records_saved' => $ok_count,'status_arr'=>$status_arr]);
}
Что я сделал до сих пор
Я могувыберите данные от пользователя (включая файл Excel).После сопоставления оно должно перейти к действию импорта, но я получаю сообщение об ошибке
Не найдено (# 404) Страница не найдена.
url: http://localhost:225/inventory-web/backend/web/meteracceptanceheader/process/import
Обновление 1
При проверке элемента в браузере я вижуmodel id
.
Я, должно быть, поступаю неправильно, чего не знаю.
Любая помощь будет принята с благодарностью.