테스트 사이트 - 개발 중인 베타 버전입니다

xml 파싱 도움좀 주세요..

· 13년 전 · 1322 · 1
11번가 파싱을 하고있습니다..

파싱법을 정확하게 모르고 구글링으로 할려고 하니깐 잘 모르겠네요..

xml은 참고소스형식으로 불러 옵니다.


메인 페이지에서
$xmlParser = new XMLParser();
$parser = @xml_parser_create();
if (!is_resource($parser)){
die("PHP XML parser에러");
} else {
xml_set_object($parser, $xmlParser);
xml_set_element_handler($parser, "startHandler", "endHandler");
xml_set_character_data_handler($parser, "cdataHandler");
}

if (!xml_parse($parser, $body, true)) {
printf("XML error: %s at line %d\n",
xml_error_string(xml_get_error_code($parser)),
xml_get_current_line_number($parser));
}

if (is_resource($parser)) {
xml_parser_free($parser);
unset( $parser );
}


이런식으로 해놓았습니다.

xml_set_element_handler($parser, "startHandler", "endHandler");
xml_set_character_data_handler($parser, "cdataHandler");

이부분이 정확하게 어떻게 처리하는지를 모르겠네요.




class XMLParser {
var $inItem = FALSE;
var $currentElement = FALSE;
var $itemInfo = array();
var $cdata = "";

function startHandler($parser, $element, $attr) {
switch ($element) {
case "ITEM":
$this->inItem = TRUE;
break;

case "TITLE" :
case "AUTHOR" :
case "COVER" :
case "PUBLISHER" :
if ($this->inItem) {
$this->currentElement = $element;
$this->cdata = "";
}
break;

default:
$this->currentElement = FALSE;
break;
}
}

function endHandler($parser, $element) {
if ($element == "ITEM") {
$this->inItem = FALSE;
$this->currentElement = FALSE;
}

if ($this->currentElement) {
$this->itemInfo[$this->currentElement] = $this->cdata;
$this->currentElement = FALSE;
$this->cdata = "";
}
}


function cdataHandler($parser, $cdata){
  if($this->inItems==TRUE){
if($this->currentElement=="PRODUCTNAME"){
$this->itemInfo["PRODUCTNAME"] = $cdata;
} else if($this->currentElement=="PRODUCTIMAGE"){
$this->itemInfo["PRODUCTIMAGE"] = $cdata;
} else if($this->currentElement=="DETAILPAGEURL"){
$this->itemInfo["DETAILPAGEURL"] = $cdata;
}   
  }
}

}

구글링해서 얻은 원본 소스는 이거인데.. 어디를 수정해야 하는지 도움좀 주십시요.
 
 
 
///////////////xml
- <ProductSearchResponse>
02   - <Request>
03     - <Arguments>
04       <Argument name="key" value="234" /> 
05       <Argument name="apiCode" value="ProductSearch" /> 
06       <Argument name="keyword" value="cp671 225/55R17" /> 
07      </Arguments>
08      <ProcessingTime>0.023 sec</ProcessingTime> 
09   </Request>
10   
11 - <Products> 
12     <TotalCount>8</TotalCount> 
13   
14 - <Product>  <==이부분 부터 물품 반복
15   <ProductCode>168246154</ProductCode> 
16 - <ProductName>
17 - <![CDATA[ 넥센타이어 NEXEN CP671 [225/55R17] 중대형 세단에 적합한 사계절 패턴 디자인, 넥센 고급 타이어, 제조일로 부터 3~4개월 이내 타이어, 왕도매 타이어
18   ]]> 
19   </ProductName>
20   <ProductPrice>90800</ProductPrice> 
21 - <ProductImage>
22 - <![CDATA[ http://i.011st.com/t/080/i/2/4/6/1/5/4/168246154_B_6.jpg
23   ]]> 
24   </ProductImage>
25 - <ProductImage100>
26 - <![CDATA[ http://i.011st.com/t/100/i/2/4/6/1/5/4/168246154_B_6.jpg
27   ]]> 
28   </ProductImage100>
29 - <Text1>
30 - <![CDATA[  
31   ]]> 
32   </Text1>
33 - <Text2>
34 - <![CDATA[  
35   ]]> 
36   </Text2>
37 - <SellerNick>
38 - <![CDATA[ 왕도매타이어
39   ]]> 
40   </SellerNick>
41   <Seller>wholetire</Seller> 
42   <SellerGrd>1</SellerGrd> 
43   <Rating>27</Rating> 
44 - <DetailPageUrl>
45 - <![CDATA[ http://www.11st.co.kr/product/SellerProductDetail.tmall?method=getSellerProductDetail&prdNo=168246154
46   ]]> 
47   </DetailPageUrl>
48   <SalePrice>71940</SalePrice> 
49 - <Delivery>
50 - <![CDATA[ 무료
51   ]]> 
52   </Delivery>
53   <ReviewCount>9</ReviewCount> 
54   <BuySatisfy>100</BuySatisfy> 
55   <MinorYn>Y</MinorYn> 
56 - <Benefit>
57   <Discount>18860</Discount> 
58   <Mileage>0</Mileage> 
59   </Benefit>
60   </Product>

댓글 작성

댓글을 작성하시려면 로그인이 필요합니다.

로그인하기

댓글 1개

13년 전
아래소스는 제가 xml처리한 다른 방식입니다.
간추려서 수정을 했습니다.
참고가 되실길 바랍니다.

---------------------------------------------
ini_set('allow_url_fopen','ON') ;

$xml = @simplexml_load_file(주소);
$cnt = count($xml->Product);

for($i=0;$i<$cnt;$i++){
print $xml->Product[$i]->ProductName;
}
---------------------------------------------
http://php.net/manual/en/function.simplexml-load-file.php

게시글 목록

번호 제목
16762
16759
16758
16755
16752
16746
16743
30241
16739
16737
16735
16734
16725
16723
16721
16720
30235
16716
30228
16714
30220
30218
30210
30206
4077
16713
16711
30190
16710
30188
16707
26290
30182
16701
16698
16691
4074
16687
16685
4070
16683
30168
16682
30166
16680
16679
16674
16671
16664
30156
16660
16657
24373
16654
16653
30150
16652
16649
4066
16647
16646
16643
16637
16634
30148
16633
16629
16627
30138
16624
16622
16619
16618
30135
30128
16615
30109
16613
16611
16606
16605
16604
16599
16594
16593
16589
16587
16572
4047
16566
30107
16564
16561
16558
16557
16552
16548
16546
16543
16526