收到此错误消息:"语法错误,意外' ='"

时间:2015-02-26 10:55:30

标签: php codeigniter csv ini

我总是收到此错误消息:

  

语法错误,意外' ='在第172行的/home/clemjon/Desktop/testListings/26350.ini中

当我检查我的ini文件时,有一个" ="在最后一行。我不知道如何删除它。

我在CSV上获取值并将其传输到ini。当我解析我创建的ini文件时抛出错误。

这是我创建CSV文件的方式:

$this->load->helper('csv');
                $this->db->select('*'); 
                $this->db->where('listing_id', $listingId);
                $query = $this->db->get('listing');

            //folder creation
                if (!is_dir('/home/clemjon/Desktop/testListings')) {
                    mkdir('/home/clemjon/Desktop/testListings', 0777, TRUE);
                }

                //file creation
                $file='/home/clemjon/Desktop/testListings/'.$listingId.'.csv';
                if(file_exists($file)){
                    unlink($file);
                }

                $this->load->helper('csv');
                $this->load->dbutil();
                $datas = $this->dbutil->csv_from_result($query);
                $this->load->helper('file');
                if ( ! write_file($file, $datas, 'a+b'))
                {
                    error_log('Unable to write the file');
                }
                else
                {
                    error_log('File written!');
                }

这就是我创建ini文件的方式(从CSV记录):

$fileName = '/home/clemjon/Desktop/testListings/'.$listingId.'.csv';
            $fp = fopen($fileName, 'r');
            $fields = fgetcsv($fp); 

            $result = array();

            while ($record = fgetcsv($fp))
            {
                $result[] = array_combine($fields, $record);
            }

            $sess_array = array();
            foreach ($result as $row) {
                $sess_array = array(
                    'current_listing_id' => $row['listing_id'],
                    'listing_description' =>$row['description'],
                    'current_listing_min_age' => $row['min_age'],
                    'current_listing_max_age' => $row['max_age'],
                    'current_listing_contact_id' => $row['contact_id']
                );
                $this->session->set_userdata($sess_array);
            }

            $this->write_ini_file($result, '/home/clemjon/Desktop/testListings/'.$listingId.'.ini', true);
            chmod("/home/clemjon/Desktop/testListings/$listingId.ini", 0775);
            $ini_array = parse_ini_file("/home/clemjon/Desktop/testListings/$listingId.ini", false);
            print_r($ini_array);

我认为创建包含额外' ='的csv时会出现问题。但我无法弄清楚是什么。任何的想法?提前谢谢

1 个答案:

答案 0 :(得分:0)

感谢Junitas! :)我只是直接从DB(现在)

获取结果
$this->db->select('*'); 
            $this->db->where('listing_id', $listingId);
            $query = $this->db->get('listing');
            $results = $query->result();

             $file='/home/clemjon/Desktop/testListings/'.$listingId.'.ini';
                if(file_exists($file)){
                    unlink($file);
                }
            $this->write_ini_file($results, $file, true);