source: temp/trunk/html/admin/develop/csv.php @ 1328

Revision 1328, 7.2 KB checked in by naka, 20 years ago (diff)

* empty log message *

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
Line 
1<?php
2
3require_once("../require.php");
4
5$conn = new SC_DBConn();
6$objView = new SC_AdminView();
7$objSess = new SC_Session();
8
9// ¥Ñ¥é¥á¡¼¥¿´ÉÍý¥¯¥é¥¹
10$objFormParam = new SC_FormParam();
11// ¥Ñ¥é¥á¡¼¥¿¾ðÊó¤Î½é´ü²½
12lfInitParam();
13$colmax = $objFormParam->getCount();
14
15// °ì»þ¥Õ¥¡¥¤¥ë̾¤Î¼èÆÀ
16$filepath = $argv[1];
17
18if(!file_exists($filepath)) {
19    fwrite(STDOUT, "no file exists.\n");
20    exit;
21}
22
23// ¥¨¥ó¥³¡¼¥É
24$enc_filepath = sfEncodeFile($filepath, "EUC-JP", CSV_TEMP_DIR);
25
26$total = 0;
27
28for($i = 0; $i < 1500; $i++) {
29    $ret = lfRegistCSV($enc_filepath, $colmax, $total);
30    $total+= $ret;
31}
32
33fwrite(STDOUT, "¢£" . $total . "·ï¤Î¥ì¥³¡¼¥É¤òÅÐÏ¿¤·¤Þ¤·¤¿¡£\n");
34
35//--------------------------------------------------------------------------------------------------------------------------
36
37/* ¥Õ¥¡¥¤¥ë¾ðÊó¤Î½é´ü²½ */
38function lfInitFile() {
39    global $objUpFile;
40    $objUpFile->addFile("CSV¥Õ¥¡¥¤¥ë", 'csv_file', array('csv'), CSV_SIZE, true, 0, 0, false);
41}
42
43/* ¥Ñ¥é¥á¡¼¥¿¾ðÊó¤Î½é´ü²½ */
44function lfInitParam() {
45    global $objFormParam;
46   
47    $objFormParam->addParam("¾¦ÉÊ̾", "name", MTEXT_LEN, "KVa", array("EXIST_CHECK","SPTAB_CHECK","MAX_LENGTH_CHECK"));
48    $objFormParam->addParam("¥«¥Æ¥´¥êID", "category_id", INT_LEN, "n", array("EXIST_CHECK","MAX_LENGTH_CHECK","NUM_CHECK"));
49    $objFormParam->addParam("¾¦ÉÊ¥³¡¼¥É", "product_code", STEXT_LEN, "KVa", array("SPTAB_CHECK","MAX_LENGTH_CHECK"));
50    $objFormParam->addParam("ÆÃÊ̲Á³Ê", "price02", PRICE_LEN, "n", array("EXIST_CHECK","MAX_LENGTH_CHECK","NUM_CHECK"));
51    $objFormParam->addParam("¾¦ÉʲÁ³Ê", "price01", PRICE_LEN, "n", array("MAX_LENGTH_CHECK","NUM_CHECK"));
52    $objFormParam->addParam("ºß¸Ë¿ô", "stock", INT_LEN, "n", array("MAX_LENGTH_CHECK","NUM_CHECK"));
53    $objFormParam->addParam("¹ØÆþÀ©¸Â", "sale_limit", INT_LEN, "n", array("MAX_LENGTH_CHECK","NUM_CHECK"));
54    $objFormParam->addParam("¥á¡¼¥«¡¼URL", "comment1", LTEXT_LEN, "KVa", array("URL_CHECK", "SPTAB_CHECK","MAX_LENGTH_CHECK"));
55    $objFormParam->addParam("¾¦ÉÊ¥¹¥Æ¡¼¥¿¥¹", "product_flag", INT_LEN, "n", array("MAX_LENGTH_CHECK","NUM_CHECK"));
56    $objFormParam->addParam("¥Ý¥¤¥ó¥ÈÉÕͿΨ", "point_rate", PERCENTAGE_LEN, "n", array("EXIST_CHECK","MAX_LENGTH_CHECK","NUM_CHECK"));
57    $objFormParam->addParam("¥á¥¤¥ó°ìÍ÷¥³¥á¥ó¥È", "main_list_comment", LTEXT_LEN, "KVa", array("EXIST_CHECK","SPTAB_CHECK","MAX_LENGTH_CHECK"));
58    $objFormParam->addParam("¥á¥¤¥ó¥³¥á¥ó¥È", "main_comment", LTEXT_LEN, "KVa", array("EXIST_CHECK","SPTAB_CHECK","MAX_LENGTH_CHECK"));
59   
60    for($i = 1; $i <= PRODUCTSUB_MAX; $i++) {
61        $objFormParam->addParam("¾ÜºÙ-¥µ¥Ö¥¿¥¤¥È¥ë($i)", "sub_title$i", LTEXT_LEN, "KVa", array("SPTAB_CHECK","MAX_LENGTH_CHECK"));
62        $objFormParam->addParam("¾ÜºÙ-¥µ¥Ö¥³¥á¥ó¥È($i)", "sub_comment$i", LTEXT_LEN, "KVa", array("SPTAB_CHECK","MAX_LENGTH_CHECK"));
63        $objFormParam->addParam("¾ÜºÙ-¥µ¥Ö²èÁü($i)", "sub_image$i", LTEXT_LEN, "KVa", array("SPTAB_CHECK","MAX_LENGTH_CHECK","FIND_FILE"));
64        $objFormParam->addParam("¾ÜºÙ-¥µ¥Ö²èÁü³ÈÂç($i)", "sub_large_image$i", LTEXT_LEN, "KVa", array("SPTAB_CHECK","MAX_LENGTH_CHECK","FIND_FILE"));
65    }
66       
67    $objFormParam->addParam("¥á¥¤¥ó°ìÍ÷²èÁü", "main_list_image", LTEXT_LEN, "KVa", array("EXIST_CHECK","SPTAB_CHECK","MAX_LENGTH_CHECK","FIND_FILE"));
68    $objFormParam->addParam("¥á¥¤¥ó¾ÜºÙ²èÁü", "main_image", LTEXT_LEN, "KVa", array("EXIST_CHECK","SPTAB_CHECK","MAX_LENGTH_CHECK","FIND_FILE"));
69    $objFormParam->addParam("¥á¥¤¥ó¾ÜºÙ³ÈÂç²èÁü", "main_large_image", LTEXT_LEN, "KVa", array("SPTAB_CHECK","MAX_LENGTH_CHECK","FIND_FILE"));
70    $objFormParam->addParam("Èæ³Ó²èÁü", "file1", LTEXT_LEN, "KVa", array("SPTAB_CHECK","MAX_LENGTH_CHECK","FIND_FILE"));
71    $objFormParam->addParam("¾¦Éʾܺ٥ե¡¥¤¥ë", "file2", LTEXT_LEN, "KVa", array("SPTAB_CHECK","MAX_LENGTH_CHECK"));
72    $objFormParam->addParam("Á÷ÎÁ", "deliv_fee", PRICE_LEN, "n", array("MAX_LENGTH_CHECK","NUM_CHECK"));
73    $objFormParam->addParam("ºß¸Ë̵À©¸Â", "stock_unlimited", INT_LEN, "n", array("MAX_LENGTH_CHECK","NUM_CHECK"));
74    $objFormParam->addParam("ÈÎÇä̵À©¸Â", "sale_unlimited", INT_LEN, "n", array("MAX_LENGTH_CHECK","NUM_CHECK"));
75}
76
77/* ÆÃ¼ì¹àÌܤÎÊÑ´¹ */
78function lfConvFormat($array) {
79    global $arrDISP;
80    foreach($array as $key => $val) {
81        switch($key) {
82        case 'status':
83            $arrRet[$key] = sfSearchKey($arrDISP, $val, 1);
84            break;
85        default:
86            $arrRet[$key] = $val;
87            break;
88        }
89    }
90    return $arrRet;
91}
92
93/* ¾¦Éʤο·µ¬Äɲà */
94function lfInsertProduct($objQuery) {
95    global $objFormParam;
96    $arrRet = $objFormParam->getHashArray();
97   
98    // µ¬³Ê¤ËÅÐÏ¿¤µ¤ì¤ëÃͤò½ü³°¤¹¤ë¡£
99    foreach($arrRet as $key => $val) {
100        switch($key) {
101        case 'product_code':
102        case 'price01':
103        case 'price02':
104        case 'stock':
105        case 'stock_unlimited':
106            break;
107        default:
108            $sqlval[$key] = $val;
109            break;
110        }
111    }
112               
113    $product_id = $objQuery->nextval("dtb_products", "product_id");
114    $sqlval['product_id'] = $product_id;
115    $sqlval['status'] = 1;  // ɽ¼¨¤ËÀßÄꤹ¤ë¡£
116    $sqlval['update_date'] = "Now()";
117    $sqlval['creator_id'] = $_SESSION['member_id'];
118   
119    if($_SESSION['member_id'] == "") {
120        $sqlval['creator_id'] = '0';
121    }
122       
123    $sqlval['rank'] = $objQuery->max("dtb_products", "rank", "delete = 0 AND category_id = ?", array($sqlval['category_id'])) + 1;
124   
125    // µ¬³ÊÅÐÏ¿
126    sfInsertProductClass($objQuery, $arrRet, $product_id);
127    // INSERT¤Î¼Â¹Ô
128    $objQuery->fast_insert("dtb_products", $sqlval);
129}
130
131/* ÆþÎÏÆâÍÆ¤Î¥Á¥§¥Ã¥¯ */
132function lfCheckError() {
133    global $objFormParam;
134    // ÆþÎϥǡ¼¥¿¤òÅϤ¹¡£
135    $arrRet =  $objFormParam->getHashArray();
136    $objErr = new SC_CheckError($arrRet);
137    $objErr->arrErr = $objFormParam->checkError(false);
138   
139    if(!isset($objErr->arrErr['category_id'])) {
140        $objQuery = new SC_Query();
141        $col = "level";
142        $table = "dtb_category";
143        $where = "category_id = ?";
144        $level = $objQuery->get($table, $col, $where, array($arrRet['category_id']));
145        if($level != LEVEL_MAX) {
146            $objErr->arrErr['category_id'] = "¢¨ ¤³¤Î¥«¥Æ¥´¥êID¤Ë¤Ï¾¦ÉʤòÅÐÏ¿¤Ç¤­¤Þ¤»¤ó¡£";
147        }
148    }
149    return $objErr->arrErr;
150}
151
152function lfRegistCSV($filepath, $colmax, $total) {
153    global $objFormParam;
154           
155    $fp = fopen($filepath, "r");
156    $line = 0;      // ¹Ô¿ô
157    $regist = 0;    // ÅÐÏ¿¿ô
158   
159    $objQuery = new SC_Query();
160   
161    $err = false;
162   
163    while(!feof($fp)) {
164        $arrCSV = fgetcsv($fp, 10000);
165        // ¹Ô¥«¥¦¥ó¥È
166        $line++;
167                       
168        // ¹àÌÜ¿ô¥«¥¦¥ó¥È
169        $max = count($arrCSV);
170       
171        // ¹àÌÜ¿ô¤¬1°Ê²¼¤Î¾ì¹ç¤Ï̵»ë¤¹¤ë
172        if($max <= 1) {
173            continue;           
174        }
175           
176        // ¹àÌÜ¿ô¥Á¥§¥Ã¥¯
177        if($max != $colmax) {
178            fwrite(STDOUT, "¢¨ ¹àÌÜ¿ô¤¬" . $max . "¸Ä¸¡½Ð¤µ¤ì¤Þ¤·¤¿¡£¹àÌÜ¿ô¤Ï" . $colmax . "¸Ä¤Ë¤Ê¤ê¤Þ¤¹¡£\n");
179           
180            ob_start();
181            print_r($arrCSV);
182            $objPage->tpl_debug = ob_get_contents();
183            ob_end_clean();
184           
185            $err = true;
186        } else {
187            // ¥·¡¼¥±¥ó¥¹ÇÛÎó¤ò³ÊǼ¤¹¤ë¡£
188            $objFormParam->setParam($arrCSV, true);
189            $arrRet = $objFormParam->getHashArray();
190            // Ãͤò¥Õ¥©¡¼¥Þ¥Ã¥ÈÊÑ´¹¤·¤Æ³ÊǼ¤¹¤ë¡£
191            $arrRet = lfConvFormat($arrRet);
192            $objFormParam->setParam($arrRet);
193            // ÆþÎÏÃͤÎÊÑ´¹
194            $objFormParam->convParam();
195            // <br>¤Ê¤·¤Ç¥¨¥é¡¼¼èÆÀ¤¹¤ë¡£
196            $objPage->arrCSVErr = lfCheckError();
197        }
198           
199        // ÆþÎÏ¥¨¥é¡¼¥Á¥§¥Ã¥¯
200        if(count($objPage->arrCSVErr) > 0) {
201            fwrite(STDOUT, "¢£" . $line . "¹ÔÌܤǥ¨¥é¡¼¤¬È¯À¸¤·¤Þ¤·¤¿¡£\n");
202            $objPage->arrParam = $objFormParam->getHashArray();
203            $err = true;
204        }
205           
206        if(!$err) {
207            $all = $total + $line;
208            fwrite(STDOUT, "writing $all\n");
209            $objQuery->begin();
210            lfInsertProduct($objQuery);
211            $objQuery->commit();
212            $regist++;
213        }
214    }
215    fclose($fp);
216   
217    return $regist;
218}
219?>
Note: See TracBrowser for help on using the repository browser.