0

我正在尝试编写用于解析上传.csv文件的代码。我已经编写了以下代码。控制器以数组的形式生成 CSV 文件的行,我也尝试使用print_r($buffer);语句打印这些行,我得到了预期的输出。虽然可以使用 打印字符串echo $string;,但在保存到数据库之前,我无法将它们传递给文本字段进行编辑。

站点控制器

public function actionImport()
{
    $buffer[] = array();
    if(isset($_POST['submitCSV'])){
        $filename=$_FILES['filename']['tmp_name'];
        $fp = fopen("$filename","r");
            if($fp){
                $i = 0;
                while(($buffer[$i++] = fgetcsv($fp,1000,",")) !== false)
                {}
                if(!feof($fp))
                    echo "Echo: Unexpected fgets() fail\n";
            }
            fclose($fp);
            unset($_POST['submitCSV']);
    }
    $this->render('index',array('buffer'=>$buffer));
}

查看(index.php)

<div class="form">
<?php echo CHtml::beginForm('site/import',$method='post',$htmlOptions =array('enctype'=>'multipart/form-data')); ?>

    <div class="row">
        <input type="hidden" name="MAX_FILE_SIZE" value="30000" />
        <input type="file" name="filename" value="file">
        <?php
            echo CHtml::submitButton('Submit', array('name'=>'submitCSV'));
            foreach($buffer as $line)
                foreach($line as $string)
                    echo CHtml::activeTextField($string,$htmlOptions = array('value'=>$string));
        ?>
</div>
<?php echo CHtml::endForm(); ?>

4

1 回答 1

0

在您的控制器中,尝试以下操作:

public function actionImport()
{
    if (isset($_POST['submitCSV'])) {
        $filename = $_FILES['filename']['tmp_name'];
        $fp = fopen("$filename", "r");
        if($fp) {
            while(($buffer = fgetcsv($fp,1000,",")) !== false)
            {
            }
            if(!feof($fp)) {
               echo "Echo: Unexpected fgets() fail\n";
            }
        }
        fclose($fp);
        if (count($buffer)) {
            $this->render('index',array('buffer' => $buffer));
        }
    }
}

在您看来:

<? foreach ($buffer as $line): ?>

   <p><? CHtml::activeTextField($line, array('class' => 'login_textbox', 'style' => 'width:100%', 'value' => $line)); ?> </p>

<? endforeach; ?>

您正在将一组数据(由您的 CSV 行组成)传递给您的视图,然后它会遍历该数组并为每个数据呈现一个文本字段。确保您启用了 short_tags。

于 2013-01-26T11:16:01.423 回答