用php中的ucfirst从数据库中大写城市名称?

时间:2017-12-22 14:57:23

标签: php ucfirst

是否可以使用例如ucfirst使{CITY}输出大写?可以通过某种方式更改此代码以使其大写吗?

<?php   
$city_meta = get_option('city_meta' );
$city_description = get_option('city_description' );
$default_api = get_option('default_api' );

/* Update Settings */
if(isset($_POST['submit_changes'])){ 
    update_option('city_meta',$_POST['city_meta']);
    update_option('city_description',$_POST['city_description']);

    $info =weatherCity::getCities();
    //$info =array_slice($info, 0, 3);  
    $sr=0;
    foreach($info as $key=>$value):
        $postTitle = 'Väder '.$value->name;
        global $wpdb;
        $pageInfo=$wpdb->get_row("SELECT ID FROM `".$wpdb->prefix."posts` WHERE post_title = '" . $postTitle . "' AND `post_type`='page' ");

        if(!empty($pageInfo)):  

            $metaTitle=$_POST['city_meta'];
            $metaDesc=$_POST['city_description'];

            $metaTitle=str_replace('{CITY}',$value->name,$metaTitle);
            $metaDesc=str_replace('{CITY}',$value->name,$metaDesc);

            update_post_meta($pageInfo->ID,'_yoast_wpseo_title',$metaTitle);
            update_post_meta($pageInfo->ID,'_yoast_wpseo_metadesc',$metaDesc);

            $sr++;
        endif;
    endforeach;



    set_error_message( _e('City Meta Settings has been updated succesfully','weather'),'0');
    foreceRedirect(admin_url('admin.php?page=city_meta') );
    exit;
}

?>

如果有人能找到一个简单的解决方案,那就太好了。 : - )

3 个答案:

答案 0 :(得分:1)

您可以使用ucwords()

$metaTitle=ucwords(str_replace('{CITY}',$value->name,$metaTitle));
$metaDesc=ucwords(str_replace('{CITY}',$value->name,$metaDesc));

这将大写字符串中每个单词的第一个字符。

PHP.Net链接

http://php.net/manual/en/function.ucwords.php

答案 1 :(得分:1)

谢谢,@ dotkomm和@Harvey Fletcher这是你的答案的组合,解决了这个问题。

解决方案如下所示:

$metaTitle=str_replace('{CITY}', ucwords($value->name),$metaTitle);
$metaDesc=str_replace('{CITY}', ucwords($value->name),$metaDesc);

答案 2 :(得分:0)

有几种方法,我认为最优雅的方法是使用css text-transform属性大写text-transform: capitalize;,因为它不会改变数据

但是ucfirst()也应该做这个工作,但是这里的数据会被改变以便进一步处理

你也可以在mysql查询中完成这项工作

在您的示例中,如果您要使用ucfirst(),则应替换

  $metaTitle=str_replace('{CITY}',$value->name,$metaTitle);
  $metaDesc=str_replace('{CITY}',$value->name,$metaDesc);

 $metaTitle=str_replace('{CITY}', ucfirst($value->name),$metaTitle);
 $metaDesc=str_replace('{CITY}', ucfirst($value->name),$metaDesc);