質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.98%

  • PHP

    17812questions

    PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

PHP:年月の文字列(2016年8月など)を並べ替えるために数値化したい

解決済

回答 4

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 203

igaiga

score 109

文字列のまま並べ替えをすると以下のように並んでしまいました。
wordpressのget_postsで並び替えたいので、元のデータを成形しなおさないといけないかと思っています。

2016年8月
2016年7月
2016年5月
2016年2月
2016年12月

並び変えるために数値に置き換えたいのですが、変換用の関数等あるのでしょうか。
また2016-12のようにしても数値として扱ってくれるのでしょうか。
それとも 2016×12+12=24204 といった感じで月数に変換したほうが良いのか、、、
一般的なやり方があればご教授いただければ幸いです。
よろしくお願いいたします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • maisumakun

    2017/09/16 11:19

    元データから「2016年8月」という形となっているのでしょうか、それとも別な形式からこのような形に変換しているのでしょうか(後者の場合、変換前のデータを並べ替えたほうが速い可能性もあります)。

    キャンセル

  • igaiga

    2017/09/16 11:23

    元データが「2016年8月」という形になっています。1000件くらいあるので手作業ではなく、一括で変換したいと思っています。よろしくお願いします。

    キャンセル

  • kei344

    2017/09/17 03:47

    「元データ」はカスタムフィールド内ですか?それとも他の項目ですか?

    キャンセル

  • igaiga

    2017/09/18 09:10

    カスタムフィールド内です。

    キャンセル

回答 4

+3

usort()を使えば、指定した基準でソートを掛けられます(リファレンス)。

usort($arr, function($first, $second){
  $regex = '/[年月]/u';
  // 配列の0要素目が年、1要素目が月
  $first_arr = preg_split($regex, $first);
  $second_arr = preg_split($regex, $second);
  $year_diff = $first_arr[0] - $second_arr[0];
  if($year_diff) return $year_diff;
  return $first_arr[1] - $second_arr[1];
});

paiza.ioで実働させたサンプル

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/09/16 11:42

    後出しで大変申し訳ございません。wordpressのget_postsで並び替えたいので、元のデータを成形しなおさないといけないかと思っています。
    usortは配列の並び替えという認識でよいでしょうか。

    キャンセル

  • 2017/09/16 11:44

    そうですね、配列の並べ替え用の関数です。

    キャンセル

checkベストアンサー

+1

一括置換のためのプラグインがあるので、それを利用されてはいかがでしょう。
※ 置換にデータベースのバックアップを採ることを強く推奨します。

【Search Regexプラグイン(記事やコメント内容を一括置換) - WordPressプラグインの一覧】
https://www.adminweb.jp/wordpress-plugin/list/index27.html

【WordPress の記事内容を一括で置換できるプラグイン Search Regex】
https://nj-clucker.com/wordpress-plug-in-search-regex/


未検証ですが、下記方法であれば取得の際に未加工でソートできるかもしれません。

【WordPressのカスタムフィールドを日付としてソートしたい - Life is Really Short, Have Your Life!!】
http://aroundthedistance.hatenadiary.jp/entry/2014/02/03/160822

【カスタムフィールドに入れた日付順に記事一覧を並べ替える方法 | TechMemo】
http://techmemo.biz/wordpress/orderby-custom-field/

【【WordPress】カスタムフィールドの日付で期間内のスケジュールだけを並べ替えて表示する │ ノラWEB屋 野良人(のらんど)】
http://norando.net/wp-meta_compare/

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/09/18 15:41

    「カスタムフィールドに入れた日付順に記事一覧を並べ替える方法」を試してみましたが、動作しませんでした。フォーラムの類似の質問を見るとY-m-dの形式にしないとダメかもしれないようなことが書いてあったのでそのせいかもしれません。
    置換でやってみます。ありがとうございました。

    キャンセル

+1

年と月だけだと文字列をsplitして数値化するという方法でも良いような気がしますが、日時の値にちゃんと変換するなら、こんな感じで。

date_default_timezone_set("Asia/Tokyo");
$a=date_create_from_format("Y年n月","1998年2月");


ソートはめんどくさい。

date_default_timezone_set("Asia/Tokyo");

$foo = array("2000年1月","1980年10月","1980年2月","1980年1月");

var_dump($foo);

array_multisort(array_map(function($x) {
        return date_create_from_format("Y年n月",$x) ;
    },$foo), SORT_ASC, $foo);

var_dump($foo);

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/09/18 14:43

    ありがとうございます。そのまま入れてみましたが、こんな感じで出ました。
    array(4) { [0]=> string(11) "2000年1月" [1]=> string(12) "1980年10月" [2]=> string(11) "1980年2月" [3]=> string(11) "1980年1月" } array(4) { [0]=> string(11) "1980年1月" [1]=> string(11) "1980年2月" [2]=> string(12) "1980年10月" [3]=> string(11) "2000年1月" }

    キャンセル

0

こんな感じで数値にすれば良くないですか?

$meta = get_post_meta( get_the_ID(), 'カスタムフィールド' ,false );
$meta = preg_replace( '/年(\d)月/', '0\1' , $meta );
$meta = preg_replace( '/年(\d{2})月/', '\1' , $meta );
Array
(
    [0] => 201602
    [1] => 201605
    [2] => 201607
    [3] => 201608
    [4] => 201612
)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/09/18 15:55

    ありがとうございます。このほうが簡単そうですね。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.98%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • PHP

    17812questions

    PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。