1. Go to this page and download the library: Download sateler/yii2-excelparser library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
sateler / yii2-excelparser example snippets
class ImportForm extends \yii\base\Model
{
private static $fields = [
'Name' => 'name',
'Code' => 'code',
'Subject' => 'subject',
];
private static $pOnEmpty' => false],
[['file'], 'file', 'skipOnEmpty' => false],
];
}
/**
* @inheritdoc
*/
public function attributeLabels()
{
return [
'file' => 'Archivo',
];
}
public function setFileProp() {
$this->file = UploadedFile::getInstance($this, 'file');
}
public function import() {
try {
$parser = new ExcelParser([
'fileName' => $this->file->tempName,
//'worksheetName' => 'Sheet 1',
'fields' => self::$fields,
'save the data in an internal array, set to false for large datasets to save memory
'saveData' => false,
// Modify parsed header columns, each item is a [name => column_number] pair
'modifyHeaderColumns' => function($cols) {
$cols["Custom Header"] = 11; // get the values from column 11 for each row as the 'Custom Header' attribute
return $cols;
},
// Callback after object has been created and parsed
'onObjectParsed' => function(SomeModel $data, $rowIndex) {
return $data->save();
},
]);
}
if ($parser->getError()) {
Yii::error("ExcelParser Error: " . $parser->getError());
$this->addError('file', 'Archivo con formato inválido');
return false;
}
// If 'savedata' is set to true, then get the data:
$allData = $parser->getData();
foreach($allData as $i => $data) {
if (!$data->save()) {
$this->addError('file', "Error en fila $i: " . implode("\n", $data->getFirstErrors()));
return false;
}
unset($allData[$i]);
}
return true;
}
}
public function actionImport()
{
$form = new ImportForm;
if ($form->load(Yii::$app->request->post()) && $form->validate()) {
if($form->import()) {
Yii::$app->session->setFlash('success', 'Success');
return $this->redirect(['import']);
}
else {
Yii::$app->session->setFlash('error', 'Error');
}
}
return $this->render('import', [
'model' => $form,
]);
}
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.