1

このコードを使用して、配列からすべてのカテゴリをクエリし、カテゴリごとに meta_key 値を合計します。

<? 
$arr_cat = array(1,34,64,32);
foreach ($arr_cat as $cat) {
  $MySum = 0;
  $args = array(
    'cat' => $cat,
    'meta_key' => 'proyecto_votos',
    'post_type' => 'proyecto',
    'posts_per_page' => '-1');
    $the_query = new WP_Query( $args);
    while ( $the_query->have_posts() ) : $the_query->the_post();
      $MySum += get_post_meta($post->ID, 'proyecto_votos', true);
    endwhile;
    wp_reset_postdata();
  }
  //var_dump($arr_cat);
?>

そして、それは正常に動作します。しかし、custom_value の合計が最も多い上位 5 つのカテゴリだけを表示することはできません。これについて私を助けてください。

本当にありがとう。

4

2 に答える 2

1

最後に、少しのグーグルで私はそれを手に入れました:-):

<? $totalvotes = get_meta_values( 'proyecto_votos', 'proyecto' ); ?>    
<? 
foreach ($arr_cat_reg as $cat) {
    $MySum = 0;
    $args = array(
    'cat' => $cat,
    'meta_key' => 'proyecto_votos',
    'post_type' => 'proyecto',
    'posts_per_page' => '-1' );        
    $the_query = new WP_Query( $args);
    while ( $the_query->have_posts() ) : $the_query->the_post();
        $MySum += get_post_meta($post->ID, 'proyecto_votos', true);
    endwhile;       
    //echo $MySum.'<br/>';              
    $percent = $MySum * 100;
    $percent = $percent / $totalvotes;              
    //echo $percent;                
    wp_reset_postdata();
    $catslug = get_cat_slug($cat);
    $most_voted[] = array('region' => $catslug, 'votos' => $MySum); 
}               
$sortArray = array();

foreach($most_voted as $region){
    foreach($region as $key=>$value){
        if(!isset($sortArray[$key])){
            $sortArray[$key] = array();
        }
        $sortArray[$key][] = $value;
    }
} 
$orderby = "votos";
array_multisort($sortArray[$orderby],SORT_DESC,$most_voted); 
$top5 = array_slice($most_voted, 0, 5);         
?>              

これが誰かに役立つことを願っています。

于 2012-07-10T06:44:36.553 に答える
1

上位 5 件の投稿のみ

$args = array(
    'cat' => $cat,
    'post_type' => 'proyecto',
    'meta_key' => 'proyecto_votos',
    'orderby'='meta_value_num',
    'posts_per_page' => '5'  // top 5 posts using ASC order by default
);

posts_per_page => -1すべての投稿を表示します。

参照。

于 2012-07-10T05:57:20.490 に答える