基本的に、「パーツ」と呼ばれるカスタム投稿タイプの設定があり、現在 5,000 件以上の投稿があります。「部品番号」を含む、各部品に関連付けられた多数のカスタム フィールドがあります。現在、各パーツの URL は次のとおりです。
http://site.com/parts/name-of-part/
私がむしろ持っているのは:
http://site.com/parts/XXXX-608-AB/ (これは部品番号で、カスタム フィールド「partno」として保存されます。)
私は2つのことをする必要があると信じています:
1) カスタム フィールド「partno」に基づいて、既存の各パーツのすべてのスラッグを一括編集するスクリプトを作成します。
2) カスタム フィールド「partno」に基づいて常に新しいパーツのスラッグを作成するようにトリガーするために、Wordpress 関数にフックします。
これらの側面の一方または両方を達成する方法について、誰かが知識を持っていますか?
更新:以下は、既存の投稿を変更するために最終的に使用したコードです
// Set max posts per query
$max = 500;
$total = 5000;
for($i=0;$i<=$total;$i+=$max) {
$parts = get_posts(array('post_type' => 'parts', 'numberposts' => $max, 'offset' => $i));
// loop through every part
foreach ( $parts as $part ) {
// get part number
$partno = get_post_meta( $part->ID, 'partno', true );
$updated_post = array();
$updated_post['ID'] = $part->ID;
$updated_post['post_name'] = $partno;
wp_update_post( $updated_post ); // update existing posts
echo $part->ID;
}
}
更新: 以下は、進行中の投稿を変更するために functions.php で使用したコードです(一部はhttps://wordpress.stackexchange.com/questions/51363/how-to-avoid-infinite-loop-in-save-post に感謝します)。 -コールバック)
add_action('save_post', 'my_custom_slug');
function my_custom_slug($post_id) {
//Check it's not an auto save routine
if ( defined('DOING_AUTOSAVE') && DOING_AUTOSAVE )
return;
//Perform permission checks! For example:
if ( !current_user_can('edit_post', $post_id) )
return;
//If calling wp_update_post, unhook this function so it doesn't loop infinitely
remove_action('save_post', 'my_custom_slug');
//call wp_update_post update, which calls save_post again. E.g:
if($partno != '')
wp_update_post(array('ID' => $post_id, 'post_name' =>get_post_meta($post_id,'partno',true)));
// re-hook this function
add_action('save_post', 'my_custom_slug');
}