xml 파싱 도움좀 주세요..

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개

아래소스는 제가 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
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
13년 전 조회 1,207
13년 전 조회 1,375
13년 전 조회 2,317
13년 전 조회 2,597
13년 전 조회 1,469
13년 전 조회 1,743
13년 전 조회 2,844
13년 전 조회 1,784
13년 전 조회 1,778
13년 전 조회 1,470
13년 전 조회 2,894
13년 전 조회 1,460
13년 전 조회 1,616
13년 전 조회 1,952
13년 전 조회 2,113
13년 전 조회 3,709
13년 전 조회 3,939
13년 전 조회 1,418
13년 전 조회 1,893
13년 전 조회 1,397
13년 전 조회 2,021
13년 전 조회 1,773
13년 전 조회 1,663
13년 전 조회 1,974
13년 전 조회 1,215
13년 전 조회 2,615
13년 전 조회 2,384
13년 전 조회 2,085
13년 전 조회 1,536
13년 전 조회 2,048
13년 전 조회 2,245
13년 전 조회 1,838
13년 전 조회 3,048
13년 전 조회 1,677
13년 전 조회 1,405
13년 전 조회 1,621
13년 전 조회 4,403
13년 전 조회 3,276
13년 전 조회 1,838
13년 전 조회 2,006
13년 전 조회 3,405
13년 전 조회 2,410
13년 전 조회 1,556
13년 전 조회 1,685
13년 전 조회 3,008
13년 전 조회 1,525
13년 전 조회 1,812
13년 전 조회 1,242
13년 전 조회 1,396
13년 전 조회 2,159
13년 전 조회 3,699
13년 전 조회 1,467
13년 전 조회 1,706
13년 전 조회 2,136
13년 전 조회 1,534
13년 전 조회 3,162
13년 전 조회 1,719
13년 전 조회 2,413
13년 전 조회 2,648
13년 전 조회 2,491
13년 전 조회 1,792
13년 전 조회 2,048
13년 전 조회 1,572
13년 전 조회 1,432
13년 전 조회 2,094
13년 전 조회 1,782
13년 전 조회 1,645
13년 전 조회 1,538
13년 전 조회 1,757
13년 전 조회 1,516
13년 전 조회 2,117
13년 전 조회 1,761
13년 전 조회 1,424
13년 전 조회 2,031
13년 전 조회 1,700
13년 전 조회 2,428
13년 전 조회 1,889
13년 전 조회 4,291
13년 전 조회 2,368
13년 전 조회 2,932
13년 전 조회 1,592
13년 전 조회 1,213
13년 전 조회 1,940
13년 전 조회 2,705
13년 전 조회 1,601
13년 전 조회 2,813
13년 전 조회 1,560
13년 전 조회 1,916
13년 전 조회 2,584
13년 전 조회 1,952
13년 전 조회 1,586
13년 전 조회 2,295
13년 전 조회 4,578
13년 전 조회 1,300
13년 전 조회 1,381
13년 전 조회 1,533
13년 전 조회 4,655
13년 전 조회 1,994
13년 전 조회 2,201
13년 전 조회 2,222