當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Varien_Io_File::streamReadCsv方法代碼示例

本文整理匯總了PHP中Varien_Io_File::streamReadCsv方法的典型用法代碼示例。如果您正苦於以下問題:PHP Varien_Io_File::streamReadCsv方法的具體用法?PHP Varien_Io_File::streamReadCsv怎麽用?PHP Varien_Io_File::streamReadCsv使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Varien_Io_File的用法示例。


在下文中一共展示了Varien_Io_File::streamReadCsv方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: parseCsv

 /**
  * Parses csv file
  *
  * @param string $file
  * @return Mage_Core_Model_Resource_Abstract
  */
 public function parseCsv($file)
 {
     $info = pathinfo($file);
     $io = new Varien_Io_File();
     $io->open(array('path' => $info['dirname']));
     $io->streamOpen($info['basename'], 'r');
     $headers = $io->streamReadCsv();
     if ($headers === false) {
         $io->streamClose();
         Mage::throwException(Mage::helper('pyro_licenses')->__('You must specify valid headers in the first row'));
     }
     if (false === ($columns = $this->_prepareColumns($headers))) {
         $io->streamClose();
         Mage::throwException(Mage::helper('pyro_licenses')->__("Invalid header: 'License' is missed"));
     }
     $this->_write->beginTransaction();
     try {
         $rowNumber = 1;
         $importData = array();
         while (false !== ($csvLine = $io->streamReadCsv())) {
             $rowNumber++;
             // check for empty lines
             $emptyLine = array_unique($csvLine);
             if (count($emptyLine) == 1 && $emptyLine[0] == "") {
                 continue;
             }
             $row = $this->_getImportRow($csvLine, $columns, $rowNumber);
             if ($row !== false) {
                 $importData[] = $row;
             }
             if (count($importData) == 5000) {
                 $this->_saveImportData($importData);
                 $importData = array();
             }
         }
         $this->_saveImportData($importData);
         $io->streamClose();
     } catch (Mage_Core_Exception $e) {
         $this->_write->rollback();
         $io->streamClose();
         Mage::throwException($e->getMessage());
     } catch (Exception $e) {
         $this->_write->rollback();
         $io->streamClose();
         Mage::logException($e);
         Mage::throwException(Mage::helper('adminhtml')->__($e->getMessage()));
     }
     $this->_write->commit();
     if ($this->_importErrors) {
         $error = sprintf('ImportSubscribers: "%1$s"', implode('", "', $this->_importErrors));
         Mage::log($error, 3, '', true);
     }
     return $this;
 }
開發者ID:artmouse,項目名稱:ProductLicense,代碼行數:60,代碼來源:Licenses.php

示例2: getPatchefiles

 public function getPatchefiles()
 {
     /* Mage::getBaseDir('etc') . DS . 'applied.patches.list'; */
     $path = BP . DS . "app" . DS . "etc" . DS;
     $filename = 'applied.patches.list';
     $filepath = $path . $filename;
     if (!file_exists($filepath)) {
         return "No Patch file found.";
     }
     if (!is_readable($filepath)) {
         return "Patch file is not readable.";
     }
     $flocal = new Varien_Io_File();
     $flocal->open(array('path' => dirname($filepath)));
     $flocal->streamOpen($filepath, 'r');
     $patch_install_version = array();
     $patch_uninstall_version = array();
     $patch_version = array();
     while (false !== ($patchFileLines = $flocal->streamReadCsv())) {
         if (strpos($patchFileLines[0], 'SUPEE') !== false) {
             $patch_name = explode('|', $patchFileLines[0]);
             $patch_install_version[] = str_replace("SUPEE-", '', $patch_name[1]);
         }
         if (strpos($patchFileLines[0], 'REVERTED') !== false) {
             $patch_name = explode('|', $patchFileLines[0]);
             $patch_uninstall_version[] = str_replace("SUPEE-", '', $patch_name[1]);
         }
     }
     $patch_install_version = array_unique($patch_install_version);
     $patch_uninstall_version = array_unique($patch_uninstall_version);
     $patch_version = array_diff($patch_install_version, $patch_uninstall_version);
     return implode(",", $patch_version);
 }
開發者ID:vijays91,項目名稱:Magento-Security-Patches,代碼行數:33,代碼來源:Data.php

示例3: loadData

 /**
  * Load the import data from the csv files
  *
  * @return array
  */
 public function loadData()
 {
     $ioHandler = new Varien_Io_File();
     $ioHandler->open(array('path' => $this->getImportDir()));
     $debitFiles = $ioHandler->ls(Varien_Io_File::GREP_FILES);
     $import = array();
     foreach ($debitFiles as $debitFile) {
         if ($debitFile['filetype'] != 'csv') {
             continue;
         }
         $country = str_replace('.csv', '', $debitFile['text']);
         $country = strtoupper($country);
         $import[$country] = array();
         $i = 1;
         $ioHandler->streamOpen($debitFile['text'], 'r');
         while (($line = $ioHandler->streamReadCsv()) !== false) {
             if ($i == 1) {
                 $i++;
                 continue;
             }
             // Check if routing number already exists
             $swiftCode = trim($line[2]);
             if (array_key_exists($swiftCode, $import[$country]) || empty($swiftCode)) {
                 continue;
             }
             // Add bank to array
             $import[$country][$swiftCode] = array('routing_number' => trim($line[0]), 'swift_code' => $swiftCode, 'bank_name' => trim($line[1]));
         }
         $ioHandler->streamClose();
     }
     return $import;
 }
開發者ID:pette87,項目名稱:Magento-DebitPayment,代碼行數:37,代碼來源:Bankdata.php

示例4: import

 /**
  * @$forceCreation true overwrites existing entities with the new values
  */
 public function import($forceCreation = false)
 {
     if (is_null($this->_entity)) {
         throw Mage::exception('Please specify a valid entity.');
     }
     if (!file_exists($this->_importFile)) {
         throw Mage::exception('Please specify a valid csv file.');
     }
     if (is_null($this->_storeId)) {
         throw Mage::exception('Please specify a valid store.');
     }
     $io = new Varien_Io_File();
     $io->streamOpen($this->_importFile, 'r');
     $io->streamLock(true);
     $firstLine = true;
     while (false !== ($line = $io->streamReadCsv())) {
         if ($firstLine) {
             $firstLine = false;
             $this->_headerColumns = $line;
             continue;
         }
         $data = array();
         foreach ($this->_headerColumns as $key => $val) {
             $data[$val] = $line[$key];
         }
         $this->_importEntity($data, $forceCreation);
     }
 }
開發者ID:aayushKhandpur,項目名稱:aayush-renting,代碼行數:31,代碼來源:Import.php

示例5: uploadAndImport

 public function uploadAndImport(Varien_Object $object)
 {
     $hlr = Mage::helper("amacart");
     if (empty($_FILES['groups']['tmp_name']['import']['fields']['blacklist']['value'])) {
         return $this;
     }
     $csvFile = $_FILES['groups']['tmp_name']['import']['fields']['blacklist']['value'];
     $io = new Varien_Io_File();
     $info = pathinfo($csvFile);
     $io->open(array('path' => $info['dirname']));
     $io->streamOpen($info['basename'], 'r');
     $emails = array();
     while (($csvLine = $io->streamReadCsv()) !== FALSE) {
         foreach ($csvLine as $email) {
             if (!Zend_Validate::is($email, 'NotEmpty')) {
             } else {
                 if (!Zend_Validate::is($email, 'EmailAddress')) {
                     $this->_warnings[] = $email . " " . $hlr->__("not valid email");
                 } else {
                     $emails[] = array("email" => $email, 'created_at' => date("Y-m-d H:i:s", time()));
                 }
             }
             if (count($emails) == 100) {
                 $this->saveImportData($emails);
                 $emails = array();
             }
         }
     }
     $this->saveImportData($emails);
     foreach (array_slice($this->_warnings, 0, 10) as $warning) {
         Mage::getSingleton('adminhtml/session')->addWarning($warning);
     }
     Mage::getSingleton('core/session')->addSuccess($hlr->__("Import completed"));
 }
開發者ID:ankita-parashar,項目名稱:magento,代碼行數:34,代碼來源:Amasty_Acart_Model_Mysql4_Blist.php

示例6: importAction

 public function importAction()
 {
     try {
         $productId = $this->getRequest()->getParam('id');
         $fileName = $this->getRequest()->getParam('Filename');
         $path = Mage::getBaseDir('var') . DS . 'import' . DS;
         $uploader = new Mage_Core_Model_File_Uploader('file');
         $uploader->setAllowedExtensions(array('csv'));
         $uploader->setAllowRenameFiles(false);
         $uploader->setFilesDispersion(false);
         $result = $uploader->save($path, $fileName);
         $io = new Varien_Io_File();
         $io->open(array('path' => $path));
         $io->streamOpen($path . $fileName, 'r');
         $io->streamLock(true);
         while ($data = $io->streamReadCsv(';', '"')) {
             if ($data[0]) {
                 $model = Mage::getModel('giftcards/pregenerated')->load($data[0], 'card_code');
                 if ($model->getId()) {
                     continue;
                 }
                 $model->setCardCode($data[0]);
                 $model->setCardStatus(1);
                 $model->setProductId($productId);
                 $model->save();
             } else {
                 continue;
             }
         }
     } catch (Exception $e) {
         $result = array('error' => $e->getMessage(), 'errorcode' => $e->getCode());
     }
     $this->getResponse()->setBody(Mage::helper('core')->jsonEncode($result));
 }
開發者ID:enjoy2000,項目名稱:gemz,代碼行數:34,代碼來源:ProductController.php

示例7: saveImportAction

 public function saveImportAction()
 {
     $request = $this->getRequest();
     $importConfig = new Varien_Object();
     $path = '';
     $delimiter = $request->getParam('delimiter', false);
     $enclosure = $request->getParam('enclosure', false);
     $importConfig->setFilePath($path)->setDelimiter($delimiter)->setEnclosure($enclosure);
     try {
         $file = $_FILES['file']['name'];
         $path = Mage::getBaseDir('var') . DS . 'import' . DS;
         $uploader = new Varien_File_Uploader('file');
         $uploader->setAllowRenameFiles(false);
         $uploader->setFilesDispersion(false);
         $uploader->save($path, $file);
         $io = new Varien_Io_File();
         $io->open(array('path' => $path));
         $io->streamOpen($path . $file, 'r');
         $io->streamLock(true);
         $map = $io->streamReadCsv($delimiter, $enclosure);
         $prodModel = Mage::getSingleton('catalog/product');
         $db = Mage::getSingleton('core/resource')->getConnection('core_write');
         $db->query('set foreign_key_checks = 0');
         while ($data = $io->streamReadCsv($delimiter, $enclosure)) {
             $prod = $prodModel->loadByAttribute('sku', $data[2]);
             if (!$prod || !$prod->getId()) {
                 continue;
             }
             $prices = Mage::getModel('customerprices/prices');
             $prices->loadByCustomer($prod->getId(), $data[0], $data[3]);
             $prices->setProductId($prod->getId());
             $prices->setCustomerId($data[0]);
             $prices->setCustomerEmail($data[1]);
             $prices->setQty($data[3]);
             $prices->setPrice($data[4]);
             $prices->setSpecialPrice($data[5]);
             $prices->save();
         }
         Mage::getSingleton('adminhtml/session')->addSuccess(Mage::helper('customerprices')->__('Prices where succesfully imported '));
     } catch (Mage_Core_Exception $e) {
         Mage::getSingleton('adminhtml/session')->addError($e->getMessage());
     } catch (Exception $e) {
         //Mage::getSingleton('adminhtml/session')->addError(Mage::helper('customergroupsprice')->__($e->getMessage().'An error occurred while importing prices.'));
         Mage::getSingleton('adminhtml/session')->addError($e->getMessage());
     }
     $this->getResponse()->setRedirect($this->getUrl("*/*/import"));
 }
開發者ID:technomagegithub,項目名稱:inmed-magento,代碼行數:47,代碼來源:ConvertController.php

示例8: _afterSave

 public function _afterSave()
 {
     if (empty(@$_FILES['groups']['tmp_name']['svea_general']['fields']['import_customer_addresses']['value'])) {
         return $this;
     } else {
         try {
             $csvFile = $_FILES['groups']['tmp_name']['svea_general']['fields']['import_customer_addresses']['value'];
             $io = new Varien_Io_File();
             $info = pathinfo($csvFile);
             $io->open(array('path' => $info['dirname']));
             $io->streamOpen($info['basename'], 'r');
             // delete all current rows
             $resource = Mage::getSingleton('core/resource');
             $connection = $resource->getConnection('core_write');
             $connection->query("DELETE FROM {$resource->getTableName('svea_webpay/customer_address')}");
             // read header
             $header = array();
             foreach ($io->streamReadCsv(';') as $k => $v) {
                 $header[$k] = $this->_fileHeaderMapping[$this->_convertCsvString($v)];
             }
             // Import rows
             while ($row = $io->streamReadCsv(';')) {
                 $row = array_combine($header, $row);
                 foreach ($row as $k => $v) {
                     $row[$k] = $this->_convertCsvString($v);
                 }
                 if ($row['status'] !== 'Active') {
                     continue;
                 }
                 // Split name into first and last name
                 foreach ($this->_splitName($row['name']) as $k => $v) {
                     $row[$k] = $v;
                 }
                 unset($row['name']);
                 $model = Mage::getModel('svea_webpay/customer_address');
                 $model->setOrgnr($row['nationalIdNumber']);
                 $model->setCountryCode($row['countryCode']);
                 $model->setAddress($row);
                 $model->save();
             }
             $io->streamClose();
         } catch (Exception $e) {
             Mage::logException($e);
             throw new Mage_Exception(Mage::helper('svea_webpay')->__("Failed to import customer addresses."));
         }
     }
 }
開發者ID:LybeAB,項目名稱:magento-module,代碼行數:47,代碼來源:Import.php

示例9: cronImportAction

 public function cronImportAction()
 {
     $request = $this->getRequest();
     $path = $request->getParam('path', false);
     $delimiter = $request->getParam('delimiter', ';');
     $enclosure = $request->getParam('enclosure', '"');
     try {
         $io = new Varien_Io_File();
         $io->streamOpen(Mage::getBaseDir() . $path, 'r');
         $io->streamLock(true);
         $map = $io->streamReadCsv($delimiter, $enclosure);
         $prodModel = Mage::getSingleton('catalog/product');
         $db = Mage::getSingleton('core/resource')->getConnection('core_write');
         $db->query('set foreign_key_checks = 0');
         $db->query("delete from {$db->getTableName('customerprices_prices')}");
         $errors = array();
         while ($data = $io->streamReadCsv($delimiter, $enclosure)) {
             $prod = $prodModel->loadByAttribute('sku', $data[1]);
             if (!$prod || !$prod->getId()) {
                 continue;
             }
             $customer = Mage::getModel('customer/customer')->setWebsiteId(1)->loadByEmail($data[0]);
             if (!$customer->getId()) {
                 Mage::log('Customer not exist - ' . $data[0], null, 'Customerprices_import.log');
                 $errors[] = $data[0];
                 continue;
             }
             $prices = Mage::getModel('customerprices/prices');
             $prices->setProductId($prod->getId());
             $prices->setCustomerEmail($data[0]);
             $prices->setCustomerId($customer->getId());
             $prices->setQty($data[2]);
             $prices->setPrice($data[3]);
             $prices->setSpecialPrice($data[4]);
             $prices->save();
         }
         echo 'FINISHED' . "\n";
         if (count($errors)) {
             echo "Check Customerprices_import.log for errors";
         }
     } catch (Mage_Core_Exception $e) {
         echo $e->getMessage();
     } catch (Exception $e) {
         echo $e->getMessage();
     }
 }
開發者ID:jronatay,項目名稱:ultimo-magento-jron,代碼行數:46,代碼來源:CronController.php

示例10: saveAction

 public function saveAction()
 {
     $request = $this->getRequest();
     $path = '';
     $delimiter = $request->getParam('delimiter', false);
     $enclosure = $request->getParam('enclosure', false);
     try {
         $file = $_FILES['file']['name'];
         $path = Mage::getBaseDir('var') . DS . 'import' . DS;
         $uploader = new Varien_File_Uploader('file');
         $uploader->setAllowRenameFiles(false);
         $uploader->setFilesDispersion(false);
         $uploader->save($path, $file);
         $io = new Varien_Io_File();
         $io->open(array('path' => $path));
         $io->streamOpen($path . $file, 'r');
         $io->streamLock(true);
         $map = $io->streamReadCsv($delimiter, $enclosure);
         while ($data = $io->streamReadCsv($delimiter, $enclosure)) {
             if ($data[0]) {
                 $model = Mage::getModel('giftcards/giftcards');
                 $model->setCardAmount($data[1]);
                 $model->setCardCode($data[0]);
                 $model->setCardStatus(1);
                 $model->save();
             } else {
                 continue;
             }
         }
         Mage::getSingleton('adminhtml/session')->addSuccess(Mage::helper('giftcards')->__('Gift Cards where succesfully imported '));
     } catch (Mage_Core_Exception $e) {
         Mage::getSingleton('adminhtml/session')->addError($e->getMessage());
     } catch (Exception $e) {
         Mage::getSingleton('adminhtml/session')->addError(Mage::helper('giftcards')->__($e->getMessage() . 'An error occurred while importing Gift Cards.'));
     }
     $this->getResponse()->setRedirect($this->getUrl("*/*/index"));
 }
開發者ID:enjoy2000,項目名稱:gemz,代碼行數:37,代碼來源:CardsloadController.php

示例11: getBankByBlz

 /**
  * Returns the bankname by given blz
  *
  * @param  string      $blz BLZ
  * @return null|string Bank Name
  */
 public function getBankByBlz($blz)
 {
     $data = $this->_loadBlzCache();
     if (!$data) {
         // open blz file handle
         $file = new Varien_Io_File();
         $file->open(array('path' => Mage::getModuleDir('etc', 'Itabs_Debit')));
         $file->streamOpen('bankleitzahlen.csv', 'r');
         // read csv stream
         while (($line = $file->streamReadCsv(';')) !== false) {
             $data[$line[0]] = $line[1];
         }
         $this->_saveBlzCache(serialize($data));
     } else {
         $data = unserialize($data);
     }
     return empty($data[$blz]) ? null : $data[$blz];
 }
開發者ID:thanakrit-promsiri,項目名稱:GermanStoreConfig,代碼行數:24,代碼來源:Data.php

示例12: uploadAndImport

 /**
  * Upload store csv file and import data from it
  *
  * @throws Mage_Core_Exception
  * @param Varien_Object $object
  * @return Bluehorse_Storelocator_Model_Storelocator
  */
 public function uploadAndImport($object)
 {
     $this->_behavior = $object->getRequest()->getPost('behavior');
     $importFile = $_FILES['import_file'];
     if (empty($importFile['tmp_name'])) {
         return;
     }
     $csvFile = $importFile['tmp_name'];
     $this->_importErrors = array();
     $this->_importedRows = 0;
     $io = new Varien_Io_File();
     $info = pathinfo($csvFile);
     $io->open(array('path' => $info['dirname']));
     $io->streamOpen($info['basename'], 'r');
     // check and skip headers
     $headers = $io->streamReadCsv();
     if ($headers === false || count($headers) < 19) {
         $io->streamClose();
         Mage::throwException(Mage::helper('bluehorse_storelocator')->__('Invalid Stores File Format'));
     }
     $adapter = $this->_getWriteAdapter();
     $adapter->beginTransaction();
     try {
         $rowNumber = 1;
         $importData = array();
         while (false !== ($csvLine = $io->streamReadCsv())) {
             $rowNumber++;
             if (empty($csvLine)) {
                 continue;
             }
             $row = $this->_getImportRow($csvLine, $rowNumber);
             if ($row !== false) {
                 $importData[] = $row;
             }
             if (count($importData) == 5000) {
                 $this->_saveImportData($importData);
                 $importData = array();
             }
         }
         if ($this->_importErrors) {
             $error = Mage::helper('bluehorse_storelocator')->__('File has not been imported. See the following list of errors: <br>%s', implode(" <br>", $this->_importErrors));
             Mage::throwException($error);
         }
         if (empty($this->_importErrors)) {
             $this->_saveImportData($importData);
         }
         $io->streamClose();
     } catch (Mage_Core_Exception $e) {
         $adapter->rollback();
         $io->streamClose();
         Mage::throwException($e->getMessage());
     } catch (Exception $e) {
         $adapter->rollback();
         $io->streamClose();
         Mage::logException($e);
         Mage::throwException(Mage::helper('bluehorse_storelocator')->__('An error occurred while import stores csv.'));
     }
     $adapter->commit();
     //add success message
     Mage::getSingleton('adminhtml/session')->addSuccess(Mage::helper('bluehorse_storelocator')->__($this->_importedRows . ' - Rows imported successfully.'));
     return $this;
 }
開發者ID:supravatweb,項目名稱:magento_extensions,代碼行數:69,代碼來源:Storelocator.php

示例13: loadfileAction


//.........這裏部分代碼省略.........
                 $i++;
             }
             $rtn["places"][$i]['label'] = "Manage Local Stock";
             $rtn["places"][$i]['value'] = "manage_local_stock";
             $rtn["places"][$i]['id'] = 'manage_local_stock';
             $rtn["places"][$i]['style'] = "manage_local_stock";
             $i++;
         }
         if ($this->getRequest()->getParam('autoSetInStock') == "0") {
             $rtn["places"][$i]['label'] = "Stock status";
             $rtn["places"][$i]['value'] = "is_in_stock";
             $rtn["places"][$i]['id'] = 'is_in_stock';
             $rtn["places"][$i]['style'] = "is_in_stock";
             $i++;
         }
         /* if ($this->getRequest()->getParam('autoSetManageStock') == "0") {
            $rtn["places"][$i]['label'] = "Manage stock";
            $rtn["places"][$i]['value'] = "manage_stock";
            $rtn["places"][$i]['id'] = 'manage_stock';
            $rtn["places"][$i]['style'] = "manage_stock";
            $i++;
            } */
         // if total stock are not sync with local stocks or  if total stock are sync with local stocks but sync is done by user
         if ($this->getRequest()->getParam('autoSetTotal') == "0") {
             $rtn["places"][$i]['label'] = "Total Stock";
             $rtn["places"][$i]['value'] = "total";
             $rtn["places"][$i]['id'] = 'total';
             $rtn["places"][$i]['style'] = "total";
             $i++;
         } else {
             $rtn["places"][$i]['label'] = "used";
             $rtn["places"][$i]['value'] = "used";
             $rtn["places"][$i]['id'] = 'used';
             $rtn["places"][$i]['style'] = "used";
             $i++;
         }
         $resource = Mage::getSingleton('core/resource');
         $read = $resource->getConnection('core_read');
         $tableEet = $resource->getTableName('eav_entity_type');
         $select = $read->select()->from($tableEet)->where('entity_type_code=\'catalog_product\'');
         $data = $read->fetchAll($select);
         $typeId = $data[0]['entity_type_id'];
         function cmp($a, $b)
         {
             return $a['attribute_code'] < $b['attribute_code'] ? -1 : 1;
         }
         /*  Liste des  attributs disponible dans la bdd */
         $attributesList = Mage::getResourceModel('eav/entity_attribute_collection')->setEntityTypeFilter($typeId)->addSetInfo()->getData();
         usort($attributesList, "cmp");
         foreach ($attributesList as $attribute) {
             if (!empty($attribute['frontend_label'])) {
                 $rtn["places"][$i]['label'] = $attribute['attribute_code'];
                 $rtn["places"][$i]['value'] = $attribute['attribute_code'];
                 $rtn["places"][$i]['id'] = "attribute-" . $attribute['attribute_code'] . "-" . $attribute['attribute_id'] . "-" . $attribute['backend_type'];
                 $rtn["places"][$i]['style'] = "attribute";
                 $i++;
             }
         }
         $rtn["places"][$i]['label'] = "not used";
         $rtn["places"][$i]['value'] = "not-used";
         $rtn["places"][$i]['id'] = 'not-used';
         $rtn["places"][$i]['style'] = "not-used";
         $i++;
         $sku_offset = $this->getRequest()->getParam('skuOffset');
         $offset = $sku_offset - 1;
         $l = 0;
         if ($fileEnclosure != "none") {
             while (false !== ($csvLine = $io->streamReadCsv($fileSeparator, $fileEnclosure)) && $l < 1000) {
                 $skus = array_splice($csvLine, $offset, 1);
                 array_unshift($csvLine, $skus[0]);
                 if (strlen($csvLine[0]) > 50) {
                     $csvLine[0] = '<span title="' . $csvLine[0] . '">' . substr($csvLine[0], 0, 50) . '...' . '</span>';
                 }
                 $rtn['body'][$l] = $csvLine;
                 $rtn['body'][$l][] = 0;
                 $l++;
             }
         } else {
             while (false !== ($csvLine = $io->streamReadCsv($fileSeparator)) && $l < 1000) {
                 $skus = array_splice($csvLine, $offset, 1);
                 array_unshift($csvLine, $skus[0]);
                 if (strlen($csvLine[0]) > 50) {
                     $csvLine[0] = '<span title="' . $csvLine[0] . '">' . substr($csvLine[0], 0, 50) . '...' . '</span>';
                 }
                 $rtn['body'][$l] = $csvLine;
                 $rtn['body'][$l][] = 0;
                 $l++;
             }
         }
         $io->streamClose();
         if ($this->getRequest()->getParam('useCustomRules')) {
             $rules = $this->getRequest()->getParam('customRules');
             foreach ($rtn['body'] as $i => $line) {
                 eval(str_replace('$C[', '$line[', $rules));
                 $rtn['body'][$i] = $line;
             }
         }
     }
     die(json_encode($rtn));
 }
開發者ID:rcclaudrey,項目名稱:dev,代碼行數:101,代碼來源:ImportsController.php

示例14: importvalidateAction

 public function importvalidateAction()
 {
     $this->_validateCustomerLogin();
     $session = $this->_getSession();
     $this->_initLayoutMessages('marketplace/session');
     $data = $this->getRequest()->getPost();
     $time = time();
     if ($data) {
         try {
             $marketplaceHelper = Mage::helper('marketplace');
             $customer = Mage::getSingleton('customer/session')->getCustomer();
             $productState = $customer->getSellerProductState();
             $productStatus = $customer->getSellerProductStatus();
             $newProductStatus = $productStatus ? $productStatus : $marketplaceHelper->getNewProductStatus();
             $newProductState = $productState ? $productState : $marketplaceHelper->getNewProductState();
             $newProductStateValue = Mage::getModel('eav/config')->getAttribute('catalog_product', 'marketplace_state')->getSource()->getOptionText($newProductState);
             $this->loadLayout();
             /** @var $import Mage_ImportExport_Model_Import */
             $import = Mage::getModel('importexport/import');
             $source = $import->setData($data)->uploadSource();
             // Modify CSV file
             $io = new Varien_Io_File();
             $io->streamOpen($source, 'r');
             $io->streamLock(true);
             $newCsvData = array();
             $i = 0;
             while ($data = $io->streamReadCsv()) {
                 if ($i == 0) {
                     $data[] = '_attribute_set';
                     $data[] = '_type';
                     $data[] = '_product_websites';
                     $data[] = 'tax_class_id';
                     $data[] = 'visibility';
                     $data[] = 'seller_id';
                     $data[] = 'marketplace_state';
                     $data[] = 'status';
                     $data[] = 'media_gallery';
                     $newCsvData[] = $data;
                 } else {
                     $data[] = 'Default';
                     $data[] = Mage_Catalog_Model_Product_Type::DEFAULT_TYPE;
                     $data[] = 'base';
                     $data[] = 0;
                     $data[] = $marketplaceHelper->getNewProductVisibility();
                     $data[] = $customer->getCompanyName();
                     $data[] = $newProductStateValue;
                     $data[] = $newProductStatus;
                     $data[] = ' ';
                     if ($this->validateSellerCSV($data)) {
                         $newCsvData[] = $data;
                     }
                 }
                 $i++;
             }
             $io->close();
             unlink($source);
             $checkPath = Mage::getBaseDir() . DS . 'media' . DS . 'marketplace/' . $customer->getId();
             if (!file_exists($checkPath)) {
                 mkdir($checkPath, 0777);
             }
             $newSource = $checkPath . DS . 'productimport.csv';
             $io = new Varien_File_Csv();
             $io->saveData($newSource, $newCsvData);
             $validationResult = $import->validateSource($newSource);
             if (!$import->getProcessedRowsCount()) {
                 $session->addError($this->__('File does not contain data or duplicate sku. Please upload another one'));
             } else {
                 if (!$validationResult) {
                     if ($import->getProcessedRowsCount() == $import->getInvalidRowsCount()) {
                         $session->addNotice($this->__('File is totally invalid. Please fix errors and re-upload file'));
                     } elseif ($import->getErrorsCount() >= $import->getErrorsLimit()) {
                         $session->addNotice($this->__('Errors limit (%d) reached. Please fix errors and re-upload file', $import->getErrorsLimit()));
                     } else {
                         if ($import->isImportAllowed()) {
                             $session->addNotice($this->__('Please fix errors and re-upload file or simply press "Import" button to skip rows with errors'), true);
                         } else {
                             $session->addNotice($this->__('File is partially valid, but import is not possible'), false);
                         }
                     }
                     // errors info
                     foreach ($import->getErrors() as $errorCode => $rows) {
                         $error = $errorCode . ' ' . $this->__('in rows:') . ' ' . implode(', ', $rows);
                         $session->addError($error);
                     }
                 } else {
                     if ($import->isImportAllowed()) {
                         $import->importSource();
                         //Process Images
                         $status = $this->_uploadZipImages($time);
                         if ($status !== false) {
                             if ($status[0] == 'success') {
                                 $returnVal = Mage::getModel('marketplace/image')->process($newCsvData, $customer->getId(), $time);
                                 if ($returnVal === true) {
                                     $customDir = Mage::getBaseDir() . DS . 'media' . DS . 'marketplace' . DS . $customer->getId() . DS . $time;
                                     self::delTree($customDir);
                                 }
                                 $session->addSuccess($this->__($status[1]), true);
                             } else {
                                 $session->addError($this->__($status[1]));
                             }
//.........這裏部分代碼省略.........
開發者ID:enjoy2000,項目名稱:gemz,代碼行數:101,代碼來源:ProductController.php

示例15: generateXml

 public function generateXml()
 {
     $x147 = "str_replace";
     $x148 = "utf8_encode";
     $x149 = "preg_match_all";
     $x14a = "preg_match";
     $x14b = "is_null";
     $x14c = "number_format";
     $x14d = "is_numeric";
     $x14e = "preg_split";
     $x14f = "utf8_decode";
     $x150 = "is_string";
     $x151 = "json_decode";
     $x152 = "is_array";
     $x153 = "array_push";
     $x154 = "print_r";
     $x155 = "version_compare";
     $x156 = "in_array";
     $x157 = "array_pop";
     $x158 = "str_pad";
     $x159 = "array_shift";
     $x15a = "array_reverse";
     $x15b = "array_values";
     $x15c = "preg_replace";
     $x15d = "strip_tags";
     $x15e = "html_entity_decode";
     $x15f = "mb_strtolower";
     $x160 = "mb_strtoupper";
     Mage::log("\n>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> --------------- START PROCESS FOR " . strtoupper($this->x165(false)) . "-----------------", null, $this->x165('.log'));
     ini_set('memory_limit', Mage::getStoreConfig("simplegoogleshopping/system/memory_limit") . 'M');
     $this->_debug = isset($_GET['debug']) ? true : false;
     include Mage::getBaseDir() . "/lib/Wyomind/Google/Requirements.php";
     $x3a = new Varien_Io_File();
     $x4f = new Varien_Io_File();
     $x52 = Mage::getBaseDir() . DS . 'var' . DS . 'tmp' . DS;
     $x53 = $x52 . "sgs_" . $this->getSimplegoogleshoppingId() . ".flag";
     $x3a->setAllowCreateFolders(true);
     if (!$this->_display) {
         $x3a->open(array('path' => $this->getPath()));
         if ($x3a->fileExists($this->x165()) && !$x3a->isWriteable($this->x165())) {
             Mage::throwException(Mage::helper('simplegoogleshopping')->__('File "\\x25\\x73" cannot be saved. Please, make sure the directory "\\x25\\x73" is writeable by web server.', $this->x165(), $this->getPath()));
         }
         $x3a->streamOpen($this->x165());
         $x4f->open(array('path' => $x52));
         if ($x4f->fileExists($x53, false)) {
             $x4f->streamOpen($x53, 'r');
             $x4d = $x4f->streamReadCsv(";");
             $x54 = $x4f->streamStat();
             if ($x4d[0] == "PROCESSING") {
                 $x55 = $x54["mtime"];
                 $x56 = $x4d[3];
                 if (!(Mage::getSingleton('core/date')->gmtTimestamp() > $x55 + $x56 * 10 || Mage::getSingleton('core/date')->gmtTimestamp() > $x55 + $x56 * 2)) {
                     Mage::throwException(Mage::helper('simplegoogleshopping')->__('File "\\x25\\x73" is already processing. Please wait the end of the process.', $this->x165(), $this->getPath()));
                 }
             }
         } else {
             $x4f->streamOpen($x53);
         }
     }
     $x57 = array("ac" => "activation_code", "ak" => "activation_key", "bu" => "base_url", "md" => "md5", "th" => "this", "dm" => "_demo", "ext" => "sgs", "ver" => "9.0.1");
     $x150(Mage::app()->getRequest()->getParam("store_id")) ? $x58 = Mage::app()->getRequest()->getParam("store_id") : ($x58 = $this->getStoreId());
     $x59 = Mage::getSingleton('core/date')->gmtDate('Y-m-d');
     $x5a = Mage::getDesign()->getSkinUrl();
     $x5b = Mage::getStoreConfig("catalog/placeholder/image_placeholder", $x58);
     $x5c = Mage::getStoreConfig("currency/options/base", $x58);
     $x5d = Mage::getStoreConfig("cataloginventory/item_options/manage_stock", $x58);
     $x5e = Mage::getStoreConfig("cataloginventory/item_options/backorders", $x58);
     $x5f = Mage::app()->getStore($x58)->getBaseUrl(Mage_Core_Model_Store::URL_TYPE_WEB, false);
     $x60 = Mage::getModel('core/store')->load($x58)->getBaseUrl();
     $x61 = Mage::app()->getStore($x58)->getBaseUrl(Mage_Core_Model_Store::URL_TYPE_MEDIA, false);
     $x62 = Mage::getStoreConfig(Mage_Tax_Model_Config::CONFIG_XML_PATH_PRICE_INCLUDES_TAX, $x58);
     $x63 = Mage::app()->getStore($x58)->getRootCategoryId();
     $x64 = Mage::app()->getStore()->getStoreId();
     $x65 = array("activation_key" => Mage::getStoreConfig("simplegoogleshopping/license/activation_key"), "activation_code" => Mage::getStoreConfig("simplegoogleshopping/license/activation_code"), "base_url" => Mage::getStoreConfig("web/secure/base_url"));
     $x150(Mage::app()->getRequest()->getParam("simplegoogleshopping_xmlitempattern")) ? $x66 = Mage::app()->getRequest()->getParam("simplegoogleshopping_xmlitempattern") : ($x66 = $this->getSimplegoogleshoppingXmlitempattern());
     $x150(Mage::app()->getRequest()->getParam("simplegoogleshopping_title")) ? $x67 = Mage::app()->getRequest()->getParam("simplegoogleshopping_title") : ($x67 = $this->getSimplegoogleshoppingTitle());
     $x150(Mage::app()->getRequest()->getParam("simplegoogleshopping_description")) ? $x68 = Mage::app()->getRequest()->getParam("simplegoogleshopping_description") : ($x68 = $this->getSimplegoogleshoppingDescription());
     $x150(Mage::app()->getRequest()->getParam("simplegoogleshopping_categories")) ? $x69 = $x151(Mage::app()->getRequest()->getParam("simplegoogleshopping_categories")) : ($x69 = $x151($this->getSimplegoogleshoppingCategories()));
     $x150(Mage::app()->getRequest()->getParam("category_filter")) ? $x6a = Mage::app()->getRequest()->getParam("category_filter") : ($x6a = $this->getSimplegoogleshoppingCategoryFilter());
     $x150(Mage::app()->getRequest()->getParam("category_type")) ? $x6b = Mage::app()->getRequest()->getParam("category_type") : ($x6b = $this->getSimplegoogleshoppingCategoryType());
     $x6c = array();
     $x6d = array();
     if ($x152($x69)) {
         foreach ($x69 as $x6e) {
             if ($x6e->checked) {
                 $x6c[] = $x6e->line;
             }
         }
         foreach ($x69 as $x6e) {
             if ($x6e->mapping != "") {
                 $x6d[$x6e->line] = $x6e->mapping;
             }
         }
     }
     if (count($x6c) < 1) {
         $x6c[] = '*';
     }
     $x150(Mage::app()->getRequest()->getParam("simplegoogleshopping_type_ids")) ? $x6f = explode(',', Mage::app()->getRequest()->getParam("simplegoogleshopping_type_ids")) : ($x6f = explode(',', $this->getSimplegoogleshoppingTypeIds()));
     $x150(Mage::app()->getRequest()->getParam("simplegoogleshopping_visibility")) ? $x70 = explode(',', Mage::app()->getRequest()->getParam("simplegoogleshopping_visibility")) : ($x70 = explode(',', $this->getSimplegoogleshoppingVisibility()));
     $x150(Mage::app()->getRequest()->getParam("simplegoogleshopping_attributes")) ? $x71 = $x151(Mage::app()->getRequest()->getParam("simplegoogleshopping_attributes")) : ($x71 = $x151($this->getSimplegoogleshoppingAttributes()));
//.........這裏部分代碼省略.........
開發者ID:GaynorH,項目名稱:prestigedrinks,代碼行數:101,代碼來源:Simplegoogleshopping.php


注:本文中的Varien_Io_File::streamReadCsv方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。