CSV上传的问题

时间:2013-01-28 14:13:04

标签: php file-upload csv yii yii-cmodel

我正在尝试使用Yii框架上传CSV文件。我添加了以下代码:

模型

<?php
    class Import extends CModel
    {
        public $name,$email,$doctor = 0,$hospital = 0,$diagnostic = 0;
        public function rules()
        {
            return array(
                array('name,email,doctor,hospital,diagnostic','required')
            );
        }

        public function  attributeNames()
        {
            return array(); 
        }
    }
?>

查看(的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')); ?>
            <?php 
                if(is_array($buffer))
                {
                    foreach($buffer as $line){ 
                        echo '<div class="clear"></div>';
                        echo CHtml::activeTextField($buffer[0],'name',array('value',$line['name']));
                        echo CHtml::activeTextField($buffer[0],'email',array('value',$line['email']));
                        echo CHtml::activeTextField($buffer[0],'doctor',array('value',$line['doctor']));
                        echo CHtml::activeTextField($buffer[0],'hospital',array('value',$line['hospital']));
                        echo CHtml::activeTextField($buffer[0],'diagnostic',array('value',$line['diagnostic']));
            }}?>
        </div>
    <?php echo CHtml::endForm(); ?>
</div>

控制器

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

此代码所面临的问题:

  1. 由于$lineImport的一个实例,我应该能够使用对象$line的元素,但我无法做到这一点。我使用了$line->'name',但是我得到了这个错误:解析错误:语法错误,意外的''名称''(T_CONSTANT_ENCAPSED_STRING),期待标识符(T_STRING)或变量(T_VARIABLE)或'{'或'$'

  2. $line在这里是model,因此我应该能够将其作为activeTextField语句中的第一个参数。我得到这个错误:get_class()期望参数1是对象,给定布尔值

  3. 第三,此代码生成相同行的文本字段五次,因此我想通过在代码中放置activeTextField来代替$i来试验0foreach循环中递增它。这会产生与2中相同的错误。

  4. 此致

1 个答案:

答案 0 :(得分:1)

首先使用CFormModel代替CModel。您可能还想删除attributeNames()功能。

问题1:$label->'name'不正确。使用$label->name

问题2&amp;如果您按上述方法进行更改,则3应该有效