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

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

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

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

PHP

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

Q&A

解決済

1回答

5046閲覧

wordpress:記事内の画像を全て取得し、その画像がどの記事の画像が記事と紐づけたい

退会済みユーザー

退会済みユーザー

総合スコア0

WordPress

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

PHP

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

0グッド

0クリップ

投稿2018/10/21 22:28

編集2018/10/22 07:12

本当に度々すみません。
wordpressで全記事内に添付されている画像を全て取得して、その画像がどの記事の画像なのか記事と紐づけたいのですがどうしたらいいでしょうか?

アイキャッチ画像は取得しない形にしたいです。メディアから本文に添付された画像のみ。

「現状」
テンプレート内

$paged = (int) get_query_var('paged'); $args = array( 'posts_per_page' => 14, 'paged' => $paged, 'post_type' => array('post','カスタム投稿01','カスタム投稿02'), 'post_status' => 'publish', ); $the_query = new WP_Query($args); if ( $the_query->have_posts() ) : while ( $the_query->have_posts() ) : $the_query->the_post(); ?> <!-- imgTextBox --> <div class="imgTextBox"> <?php $category = get_the_category(); $cat_id = $category[0]->cat_ID; $cat_name = $category[0]->cat_name; $cat_slug = $category[0]->category_nicename; ?> <?php if(has_post_thumbnail()) : $thumb = get_the_post_thumbnail(); else: $thumb = get_post_image(get_the_content()); endif; ?> <p class="textP"><a href="<?php the_permalink(); ?>"><?php the_title(); ?></a><br><span class="postDate"><?php echo get_the_date( $format, $post ); ?></span><span class="writeName"><?php the_author(); ?></span><span class="catName"><?php echo $cat_name; ?></span></p> <p class="imgP"><a href="<?php the_permalink(); ?>"><?php the_post_thumbnail($thumb); ?></a></p> </div> <!-- imgTextBox --> <?php endwhile; ?> <?php else: ?> <?php endif; ?> </div> <div class="pagination"> <?php if (have_posts() && function_exists("pagination")) { // 一覧ページネーション pagination($wp_query->max_num_pages); } ?>

「function.php」

//投稿全画像取得 function get_post_image($content="", $idx=0) { $thumb = ""; if(strlen($content) === 0) return $thumb; // imgタグのwp-image-ID クラスを検索 preg_match_all('/wp-image-(\d+)/', $content, $m); if(count($m[1]) > 0) { while(!isset($m[1][$idx])) { $idx--; if($idx < 0) break; } // $m[1][$idx] = attachment_id if($idx > -1) $thumb = wp_get_attachment_image($m[1][$idx]); } return $thumb; }

これで全記事の全ての画像を取得して、その画像がどの記事のものか記事と紐づけできると思ったのですが、
アイキャッチ画像しか取得できませんでした。

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

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

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

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

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

guest

回答1

0

ベストアンサー

こんな感じでどうでしょう。

php

1<?php 2 $args = array( 3 'post_type' => 'post', 4 'posts_per_page' => -1, 5 ); 6 $the_query = new WP_Query($args); 7if( $the_query->have_posts() ): 8while( $the_query->have_posts() ): $the_query->the_post(); 9?> 10<div><?php $output = preg_match_all('/<img.+?src=[\'"]([^\'"]+)[\'"].*?>/i', $post->post_content, $matches); 11 12 $all_img = $matches[1]; 13if( !empty( $all_img) ) { 14 echo get_the_title(); 15 foreach( $all_img as $img ) { 16 echo '<img src="'.$img.'">'; 17 } 18} 19?></div> 20<?php endwhile; 21wp_reset_postdata(); 22else: ?> 23<!-- 投稿が無い場合の処理 --> 24<?php endif; ?> 25

とりあえず、タイトルと画像を取ってきてるだけなのであとは表示したい形に変えてみてください。
(ただ、imgタグを拾っているので、本文に画像以外のimgタグを使っていればそれも拾ってしまうと思います)

投稿2018/10/22 02:11

8-0_nyan5

総合スコア2352

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

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

退会済みユーザー

退会済みユーザー

2018/10/22 02:13

ありがとうございます。記事の最初の画像を取得やサムネイルを取得という方法ならたくさん検索にでてきたのですが、これはでてこず。助かります。試してみます!
退会済みユーザー

退会済みユーザー

2018/10/22 06:04

やってみました!うまくいきました!あとはページャーの設定だけなのでがんばります!ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問