カテゴリー
SugiBlog Webエンジニアのためのお役立ちTips

文字列を処理し、変数に代入する parse_str

void parse_str ( string $str [, array &$arr] )

str
 入力文字列
arr
 この引数を指定した場合、配列としてここで指定した変数に保存される

例)

$query_string = "last_name=%8ER%93c&first_name=%91%BE%98Y";

parse_str($query_string, $array);
結果
array(2) {
["last_name"]=>
string(4) "山田"
["first_name"]=>
string(4) "太郎"
}

※extractとの違い
parse_strはクエリ文字列を解析しスカラー変数(または配列変数)にセットする関数、extractは配列をスカラー変数にセットする関数である。

1,516 views

クエリ文字列を生成 http_build_query

string http_build_query ( array $formdata [, string $numeric_prefix [, string $arg_separator]] )

formdata
 配列、もしくはオブジェクト
numeric_prefix
 インデックスが数値の場合、指定したパラメーターがインデックスの前に追加される
arg_separator
 &などのセパレータを指定(指定しない場合はarg_separator.outputの値が使用される)

例1)

$DATA["last_name"] = "山田";
$DATA["first_name"] = "太郎";

$query_string = http_build_query($DATA, null, "&");

echo $query_string;

結果

last_name=%8ER%93c&first_name=%91%BE%98Y

例2)

$DATA[0] = "山田";
$DATA[1] = "太郎";

$query_string = http_build_query($DATA, "st", "&");

echo $query_string;

結果

st0=%8ER%93c&st1=%91%BE%98Y
1,770 views

PHP preg_matche_all(正規表現)

<?php

$url = "http://www.yahoo.co.jp/";

// 正規表現パターン
$pattern = "/http:\/\/(.*)\.([[:alpha:]]{3,})\.([[:alpha:]\.\-_]{1,}).*/";

// 正規表現で値を取得
preg_match_all ($pattern, $url, $matches);

// $matches[0]はパターン全体にマッチした文字列の配列
for($i = 0; $i < count($matches[0]); $i++)
{
  echo $matches[0][$i].PHP_EOL;
}

// $matches[$j]は第$jのキャプチャ用サブパターンにマッチした文字列の配列
for($j = 1; $j < count($matches); $j++)
{
  for($i = 0; $i < count($matches[$j]); $i++)
  {
    echo $matches[$j][$i].PHP_EOL;
  }
}

?>

出力結果:
http://www.yahoo.co.jp/
www
yahoo
co.jp

1,021 views

XMLをPHP1行で解析

foreach(simplexml_load_file("ファイルのパス")->item as $it) echo $it->description
1,127 views

PHPでXMLファイルの解析

まずはXMLのサンプル

<?xml version="1.0" encoding="UTF-8" ?>
<rdf:RDF
  xmlns="http://purl.org/rss/1.0/"
  xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
  xmlns:dc="http://purl.org/dc/elements/1.1/"
  xmlns:admin="http://webns.net/mvcb/"
  xml:lang="ja">
  <channel rdf:about="http://www.example.jp/test.rdf">
    <title>title</title>
    <link>http://www.example.jp/</link>
    <dc:date>2006-07-06T20:14:34+09:00</dc:date>
    <description>description</description>
    <admin:generatorAgent rdf:resource="http://www.infomaker.jp/editorlite/?v=0.92b" />
    <items>
      <rdf:Seq>
        <rdf:li rdf:resource="http://www.example.jp/#he20060706"/>
      </rdf:Seq>
    </items>
  </channel>

  <item rdf:about="http://www.example.jp/#he20060706">
    <title>test</title>
    <link>http://www.example.jp/</link>
    <dc:date>2006-07-06</dc:date>
    <description>description</description>
  </item>

</rdf:RDF>

PHPで解析します。

// XMLファイルを読み込みインスタンスを生成
$xml = simplexml_load_file("ファイルのパス");
//$xml = new SimpleXMLElement("ファイルのパス", null, true); // この書き方でも可

// channel要素がある場合
//$channel = $xml->channel;
// 下のforeach取り出し元配列を$channel->itemに変更

foreach($xml->item as $item) {

    // 各内容を変数に格納
    //{
        $url         = $item->link;
        $title       = $item->title;
        $description = $item->description;

        // Namespace付の子要素を取得
        //{
            // childrenメソッドにて取得(引数のURLはxmlns:dc=[URL]から取得)
            $dc = $item->children('http://purl.org/dc/elements/1.1/');

            $date = date("Y-m-d", strtotime($dc->date));
        //}
    //}

}

dcとは?

Dublin Coreの略。
Dublin Coreモジュールとは、標準的なメタデータ記述要素として用いられるDublin CoreのDCMESを利用するモジュールです。

2,303 views