- Yoastが生成するサイトマップURLからの取得が簡単
- 記事タイトルなどと関連付けたい場合はMySQL
- プラグインやPHPで取得することも可
方法1:Yoastのsitemapから記事URL一覧を取得する
WordPressのプラグイン「Yoast SEO」をインストールし、XMLサイトマップ機能をONにします。
すると、「https://URL/sitemap_index.xml」という場所に、xml形式のサイトマップができます。
そして、リンクを辿ると、以下のようにURLの一覧が出てきます。
これをコピー&ペーストするのが一番簡単だと思います。
方法2:MySQLで記事URL一覧を取得する
URLと記事のタイトルなどの情報を併せて出力したい場合には、MySQLから取得するといいと思います。wp_postテーブル(マルチサイトの場合は、wp_番号_テーブル)に必要な情報が入っていますのでSQL文で出力します。
select guid,post_name,post_title from wp_posts where ( post_type = ('post' or 'page') and post_status = 'publish');
例えば、phpMyAdminでは以下のようにSQLクエリを入力します。
すると、出力結果は以下のようになります。
WordPressのデータベース内に保存されているURLは「?p=番号」で始まる形式ですので、表示用URLが必要な場合は、Excel等でpost_nameを補い、再生成するといいと思います。
方法3:プラグインで記事URL一覧を取得する
WordPressには、記事リストを出力するプラグインがあります。このようなプラグインを利用するのも1つの方法です。
List URLs
Export All URLs
方法4:PHPで記事URL一覧を取得する
以下のようなコードのPHPファイルを作ります。そして、WebサーバのルートディレクトリにPHPを置き、Webブラウザからアクセスします。
<?php include "wp-load.php"; $posts = new WP_Query('post_type=any&posts_per_page=-1&post_status=publish'); $posts = $posts->posts; header('Content-type:text/plain'); foreach($posts as $post) { switch ($post->post_type) { case 'revision': case 'nav_menu_item': break; case 'page': $permalink = get_page_link($post->ID); break; case 'post': $permalink = get_permalink($post->ID); break; case 'attachment': $permalink = get_attachment_link($post->ID); break; default: $permalink = get_post_permalink($post->ID); break; } echo "\n{$permalink}"; //echo "\n{$post->post_type}\t{$permalink}\t{$post->post_title}"; } ?>
技巧的なテクニックです。詳細は以下のサイトをご覧ください。
参考:How to Get a List of All WordPress Post URLs by BLOGGERSIGNAL
まとめ
GoogleウェブマスターツールにURLを連投する際に、どうしようと思ったらこの方法に辿り着きました。おそらくYoastかMySQLで事足りるかと思います。もし、頻繁に利用するようでしたら、プラグインやPHPの力に頼るといいと思います。ぜひ、効率的な管理にお役立てください。