1

domdocumentを発見し、以前は正規表現を使用していました。

すべての入力を含むフォーム要素全体を返す必要があります。

ドキュメント全体を作成する必要はありません。操作できる文字列で、その部分だけを作成します。私はそれを何か便利なものにしようとして次のコードのチャンクをいじっていますが、これまでのところ何もありません。

正規表現に戻る前に、誰かがこれを理解できますか?

//get HTML into variable
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, 'https://www.openroadlending.com/Apply.aspx?aid=134');
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$html=curl_exec($curl);

$dom = new domDocument;
@$dom->loadHTML($html);
$dom->preserveWhiteSpace=false;

$xpath = new DOMXPath($dom);
$body = $xpath->query('html/');

echo var_dump($body);

//echo $body->item(0);
$inputs = $xpath->getElementsByTagName('form');

// foreach($inputs as $in){
// $input = $in->saveHTML;
// //echo $input;
// }
4

2 に答える 2

3

DOMXPath方法はありませんgetElementsByTagName。いくつかの方法でフォームにアクセスできます

  1. getElementsByTagName

    $forms = $dom->getElementsByTagName('form');
    
  2. XPathクエリ

    $forms = $xpath->query('//form');
    

目的のフォームを取得したら(コレクションから選択する$formsか、より特殊なXPathクエリを使用して)、次を使用してHTMLを文字列として取得できます。

$formHTML = $dom->saveHTML($form);
于 2013-02-02T08:59:52.463 に答える
2

この機能を使用できます

function DOMinnerHTML($element) 
{ 
   $innerHTML = ""; 
   $children = $element->childNodes; 
   foreach ($children as $child) 
   { 
      $tmp_dom = new DOMDocument(); 
      $tmp_dom->appendChild($tmp_dom->importNode($child, true)); 
      $innerHTML.=trim($tmp_dom->saveHTML()); 
   } 
   return $innerHTML; 
}

このように使用します

$productspec=$dom->getElementsByTagName('form')
foreach($productspec as $data)
{ 
   echo DOMinnerHTML($data);
}

この関数は、クラスごとに要素を取得するために使用できます

function GetBYClass($Doc,$ClassName){
    $finder = new DomXPath($Doc);
    return($finder->query("//*[contains(@class, '$ClassName')]"));
} 

この機能はこの質問とは関係ありませんが、便利です

function ExtractText($node) {
     if($node==NULL)return false;    
     if (XML_TEXT_NODE === $node->nodeType || XML_CDATA_SECTION_NODE === $node->nodeType) {
         return $node->nodeValue;
     } else if (XML_ELEMENT_NODE === $node->nodeType || XML_DOCUMENT_NODE === $node->nodeType || XML_DOCUMENT_FRAG_NODE === $node->nodeType) {
       if ('script' === $node->nodeName) return '';

     $text = '';
     foreach($node->childNodes as $childNode) {
        $text .= $this->extractText($childNode);
     }
     return $text;
     }
}
于 2013-02-02T09:11:47.017 に答える