目次
プログラムで記事を投稿する方法
$id = wp_insert_post([
'post_title' => $title,
'post_content' => $content,
'post_type' => 'post',
]);
その他のパラメータ
'ID' => [ <投稿 ID> ] // 既存の投稿を更新する場合に指定。
'post_content' => [ <文字列> ] // 投稿の全文。
'post_name' => [ <文字列> ] // 投稿のスラッグ。
'post_title' => [ <文字列> ] // 投稿のタイトル。
'post_status' => [ 'draft' | 'publish' | 'pending'| 'future' | 'private' | 登録済みカスタムステータス ] // 公開ステータス。デフォルトは 'draft'。
'post_type' => [ 'post' | 'page' | 'link' | 'nav_menu_item' | カスタム投稿タイプ ] // 投稿タイプ。デフォルトは 'post'。
'post_author' => [ <ユーザー ID> ] // 作成者のユーザー ID。デフォルトはログイン中のユーザーの ID。
'ping_status' => [ 'closed' | 'open' ] // 'open' ならピンバック・トラックバックを許可。デフォルトはオプション 'default_ping_status' の値。
'post_parent' => [ <投稿 ID> ] // 親投稿の ID。デフォルトは 0。
'menu_order' => [ <順序値> ] // 固定ページを追加する場合、メニュー内の並び順を指定。デフォルトは 0。
'to_ping' => // スペースまたは改行で区切った、ピンを打つ予定の URL のリスト。デフォルトは空文字列。
'pinged' => // スペースまたは改行で区切った、ピンを打った URL のリスト。デフォルトは空文字列。
'post_password' => [ <文字列> ] // 投稿パスワード。デフォルトは空文字列。
'guid' => // 普通はこれを指定せず WordPress に任せてください。
'post_content_filtered' => // 普通はこれを指定せず WordPress に任せてください。
'post_excerpt' => [ <文字列> ] // 投稿の抜粋。
'post_date' => [ Y-m-d H:i:s ] // 投稿の作成日時。
'post_date_gmt' => [ Y-m-d H:i:s ] // 投稿の作成日時(GMT)。
'comment_status' => [ 'closed' | 'open' ] // 'open' ならコメントを許可。デフォルトはオプション 'default_comment_status' の値、または 'closed'。
'post_category' => [ array(<カテゴリー ID>, ...) ] // 投稿カテゴリー。デフォルトは空(カテゴリーなし)。
'tags_input' => [ '<tag>, <tag>, ...' | array ] // 投稿タグ。デフォルトは空(タグなし)。
'tax_input' => [ array( <タクソノミー> => <array | string>, ...) ] // カスタムタクソノミーとターム。デフォルトは空。
'page_template' => [ <文字列> ] // テンプレートファイルの名前、例えば template.php 等。デフォルトは空。
記事にメタデータをつける方法
add_post_meta($id, 'meta_key', $val, true);
メタデータとは
基本のデータとは別にほかのデータをつけたい場合に管理することができる機能です。
パラメータ
$post_id
(整数) (必須) カスタムフィールドを追加する投稿の ID。
初期値: なし
$meta_key
(文字列) (必須) カスタムフィールドのキー。
初期値: なし
$meta_value
(mixed) (必須) カスタムフィールドの値。配列を与えるとシリアライズされて文字列が格納されます。
初期値: なし
$unique
(真偽値) (オプション) キーをユニークにするかどうか。true のときは、指定した投稿に $meta_key を持つカスタムフィールドが無いときのみ追加し、すでにカスタムフィールドが存在していれば追加されません。
初期値: false