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

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

新規登録して質問してみよう
ただいま回答率
85.48%
WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

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

Q&A

解決済

1回答

495閲覧

phpのデータフォーマットにTがある日付と現在時間を比較したいのです。どこがおかしいのでしょうか?

Samson818

総合スコア162

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

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

0グッド

0クリップ

投稿2023/04/21 07:47

編集2023/04/21 07:49

実現したいこと

WordPressにてカスタムフィールドに作成した「公開終了日時」を過ぎているもの一覧表示からはじきたいです。

前提としてカスタムフィールドは以下の様な表示になります

php

1$closeTime = post_custom('close_time'); 2echo $closeTime;//2033-04-21T15:00

以下のコード内で現在時間と比較してはじきたいのですが、
ページを読み込みし直すたびに別の記事が表示されてしまいます。

時間のフォーマットにTがあるので上手く比較できないのだろうとにらんで、
現在時刻にもTを入れてみたのですが、うまく動きません。

時間のフォーマットをいろいろ加工して試していますが、正解にたどり着かず。
どのように書けば非公開日時を過ぎた記事をはじけますでしょうか?

よろしくお願いいたします。

php

1 $day = date_i18n('Y-m-d'); 2 $time = date_i18n('H:i'); 3 $currentTime = $day.'T'.$time; 4$program = get_query_var( 'article-cat' ); 5$args = array( 6 'post_type' => 'post', 7 //'post_status' => 'publish', 8 'order' => 'DESC', 9 'orderby' => 'meta_value_num', 10 'paged' => $paged, //ページャー用 11 'posts_per_page' => 15, 12 13 'meta_query' => array( 14 array( 15 'key' => 'close_time',//---------------------------------------問題の箇所はこちら--------------------------// 16 'value' => $currentTime, 17 'compare' => '>=',//記事非表示時間より前なら表示 18 'type' => 'DATE' 19 ) 20 ), 21 'tax_query' => array( 22 array( 23 'taxonomy' => 'category', //タクソノミーを指定 24 'field' => 'slug', 25 'terms' => $program 26 ), 27 ) 28 ); 29 print_r($args); 30 $top_news = new WP_Query( $args ); 31 while($top_news->have_posts()): $top_news->the_post(); //以下略 ?>

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

PHP

1$closeTime="2033-04-21T15:00"; 2$dt1=strtotime($closeTime); 3$now=date('Y-m-d H:i:s'); 4$dt2=strtotime($now); 5print_r([date('Y-m-d H:i:s',$dt1),date('Y-m-d H:i:s',$dt2)]); 6print_r([$dt1,$dt2]);

投稿2023/04/21 08:06

yambejp

総合スコア114806

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Samson818

2023/04/21 08:16

ありがとうございます。 strtotimeテスト済でした。 'key' => 'close_time' でキーを指定しなければならず、 そこで取得した日時をkeyの中で変換して使用する方法がわかれば、strtotimeも使えると思います。
Samson818

2023/04/21 08:19

これは正解です。 'meta_query' => array( array( 'key' => 'close_time', 'value' => $currentTime, 'compare' => '>=',//記事非表示時間より前なら表示 'type' => 'DATE' ) ), これは間違いです。「2033-04-21T15:00」というカスタムフィールドはないので。 'meta_query' => array( array( 'key' => '2033-04-21T15:00', 'value' => $currentTime, 'compare' => '>=',//記事非表示時間より前なら表示 'type' => 'DATE' ) ),
yambejp

2023/04/21 08:19

コメントいただいた意味がよくわからないのですが 命題では$closeTime には文字列としての日付が投入されると書いてあると思ったのですが違うのでしょうか? 文字列で命題の通りの文字表記であればstrtotimeで時間に変更可能ですというのが私の回答です
Samson818

2023/04/24 01:27

変換したものをどう'meta_query' の中で使用すれば良いのかがわからないのです。 以下では画面をリロードするごとに表示される記事が異なってしまうのです。 $day = date_i18n('Y-m-d'); $time = date_i18n('H:i'); $currentTime = $day.'T'.$time; 'meta_query' => array( array( 'key' => 'close_time', 'value' => $currentTime, 'compare' => '>=',//記事非表示時間より前なら表示 'type' => 'DATE' ) )
Samson818

2023/04/24 02:26

不具合の箇所が異なりました。 質問的にミスリードしてしまっているのでクローズさせていただきます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問