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

Revision 5002, 7.3 KB checked in by kakinaka, 20 years ago (diff)

blank

  • 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    if (DB_TYPE == "pgsql") {
114        $product_id = $objQuery->nextval("dtb_products", "product_id");
115        $sqlval['product_id'] = $product_id;
116    }
117    $sqlval['status'] = 1;  // ɽ¼¨¤ËÀßÄꤹ¤ë¡£
118    $sqlval['update_date'] = "Now()";
119    $sqlval['creator_id'] = $_SESSION['member_id'];
120   
121    if($_SESSION['member_id'] == "") {
122        $sqlval['creator_id'] = '0';
123    }
124       
125    $sqlval['rank'] = $objQuery->max("dtb_products", "rank", "del_flg = 0 AND category_id = ?", array($sqlval['category_id'])) + 1;
126   
127    // µ¬³ÊÅÐÏ¿
128    sfInsertProductClass($objQuery, $arrRet, $product_id);
129    // INSERT¤Î¼Â¹Ô
130    $objQuery->fast_insert("dtb_products", $sqlval);
131    if (DB_TYPE == "mysql") {
132        $product_id = $objQuery->nextval("dtb_products", "product_id");
133    }
134}
135
136/* ÆþÎÏÆâÍÆ¤Î¥Á¥§¥Ã¥¯ */
137function lfCheckError() {
138    global $objFormParam;
139    // ÆþÎϥǡ¼¥¿¤òÅϤ¹¡£
140    $arrRet =  $objFormParam->getHashArray();
141    $objErr = new SC_CheckError($arrRet);
142    $objErr->arrErr = $objFormParam->checkError(false);
143   
144    if(!isset($objErr->arrErr['category_id'])) {
145        $objQuery = new SC_Query();
146        $col = "level";
147        $table = "dtb_category";
148        $where = "category_id = ?";
149        $level = $objQuery->get($table, $col, $where, array($arrRet['category_id']));
150        if($level != LEVEL_MAX) {
151            $objErr->arrErr['category_id'] = "¢¨ ¤³¤Î¥«¥Æ¥´¥êID¤Ë¤Ï¾¦ÉʤòÅÐÏ¿¤Ç¤­¤Þ¤»¤ó¡£";
152        }
153    }
154    return $objErr->arrErr;
155}
156
157function lfRegistCSV($filepath, $colmax, $total) {
158    global $objFormParam;
159           
160    $fp = fopen($filepath, "r");
161    $line = 0;      // ¹Ô¿ô
162    $regist = 0;    // ÅÐÏ¿¿ô
163   
164    $objQuery = new SC_Query();
165   
166    $err = false;
167   
168    while(!feof($fp)) {
169        $arrCSV = fgetcsv($fp, 10000);
170        // ¹Ô¥«¥¦¥ó¥È
171        $line++;
172                       
173        // ¹àÌÜ¿ô¥«¥¦¥ó¥È
174        $max = count($arrCSV);
175       
176        // ¹àÌÜ¿ô¤¬1°Ê²¼¤Î¾ì¹ç¤Ï̵»ë¤¹¤ë
177        if($max <= 1) {
178            continue;           
179        }
180           
181        // ¹àÌÜ¿ô¥Á¥§¥Ã¥¯
182        if($max != $colmax) {
183            fwrite(STDOUT, "¢¨ ¹àÌÜ¿ô¤¬" . $max . "¸Ä¸¡½Ð¤µ¤ì¤Þ¤·¤¿¡£¹àÌÜ¿ô¤Ï" . $colmax . "¸Ä¤Ë¤Ê¤ê¤Þ¤¹¡£\n");
184           
185            ob_start();
186            print_r($arrCSV);
187            $objPage->tpl_debug = ob_get_contents();
188            ob_end_clean();
189           
190            $err = true;
191        } else {
192            // ¥·¡¼¥±¥ó¥¹ÇÛÎó¤ò³ÊǼ¤¹¤ë¡£
193            $objFormParam->setParam($arrCSV, true);
194            $arrRet = $objFormParam->getHashArray();
195            // Ãͤò¥Õ¥©¡¼¥Þ¥Ã¥ÈÊÑ´¹¤·¤Æ³ÊǼ¤¹¤ë¡£
196            $arrRet = lfConvFormat($arrRet);
197            $objFormParam->setParam($arrRet);
198            // ÆþÎÏÃͤÎÊÑ´¹
199            $objFormParam->convParam();
200            // <br>¤Ê¤·¤Ç¥¨¥é¡¼¼èÆÀ¤¹¤ë¡£
201            $objPage->arrCSVErr = lfCheckError();
202        }
203           
204        // ÆþÎÏ¥¨¥é¡¼¥Á¥§¥Ã¥¯
205        if(count($objPage->arrCSVErr) > 0) {
206            fwrite(STDOUT, "¢£" . $line . "¹ÔÌܤǥ¨¥é¡¼¤¬È¯À¸¤·¤Þ¤·¤¿¡£\n");
207            $objPage->arrParam = $objFormParam->getHashArray();
208            $err = true;
209        }
210           
211        if(!$err) {
212            $all = $total + $line;
213            fwrite(STDOUT, "writing $all\n");
214            $objQuery->begin();
215            lfInsertProduct($objQuery);
216            $objQuery->commit();
217            $regist++;
218        }
219    }
220    fclose($fp);
221   
222    return $regist;
223}
224?>
Note: See TracBrowser for help on using the repository browser.