我想从一个数组中产生一个这样的字符串:
omc_playroom.id,omc_playroom.name,omc_playroom.parentid,
omc_playroom.status,omc_playroom.table_id,omc_playroom.lang_id我试过了,但它只为第一个添加了omc_playroom。
$fields = array('id, name, parentid, status, table_id, lang_id');
$module ='playroom';
$playrooms = getAll($fields, $module);
echo $playrooms;
function getAll($fields, $module){
$string = '';
$module_table = 'omc_' . $module;
foreach ($fields as $field){
$string .= ",$module_table.$field";
}
$string = substr($string, 1); // Remove leading ","
return $string;
}这会产生以下结果:
omc_playroom.id,name,parentid,status,table_id,lang_id如何在每一项前面添加omc_playroom?
发布于 2011-03-27 18:48:12
首先,您并没有真正的items数组:所有的items都在一个string中,这是您的$fields数组中唯一的元素。
让我们提取该项,并删除','分隔符后面有时出现的空格:
$fields = array('id, name,parentid,status,table_id,lang_id');
$str = $fields[0];
$str = str_replace(' ', '', $str);现在,我们使用','作为分隔符,拆分$str字符串:
$items = explode(',', $str);并循环结果数组,将前缀添加到每个元素:
foreach ($items as & $item) {
$item = 'omc_' . $item;
}最后,我们可以将这些元素内爆在一起,并响应结果:
$new_str = implode(',', $items);
echo $new_str;然后我们得到:
omc_id,omc_name,omc_parentid,omc_status,omc_table_id,omc_lang_id这似乎就是你所期望的。
但是,当然,如果您的$fields变量确实包含真正的正确数组:
$fields = array('id', 'name', 'parentid', 'status', 'table_id', 'lang_id');事情会简单得多:你只需要遍历这个数组:
$fields = array('id', 'name', 'parentid', 'status', 'table_id', 'lang_id');
foreach ($fields as & $field) {
$field = 'omc_' . $field;
}
var_dump($fields);然后你就会得到:
array
0 => string 'omc_id' (length=6)
1 => string 'omc_name' (length=8)
2 => string 'omc_parentid' (length=12)
3 => string 'omc_status' (length=10)
4 => string 'omc_table_id' (length=12)
5 => &string 'omc_lang_id' (length=11)发布于 2011-03-27 18:45:32
试试这个,因为你现在有一个只有一个元素的数组。
$fields = array('id', 'name', 'parentid', 'status', 'table_id', 'lang_id');发布于 2018-01-05 05:53:30
因为你有一个“变量分隔符”,所以preg_replace()只需一步就可以做到这一点。
代码:(Demo)
$fields=['id, name,parentid,status,table_id,lang_id'];
$module='playroom';
$module_table='omc_'.$module;
echo preg_replace('/^|,\K ?/',"$module_table.",$fields[0]);
// start of string-^
// OR---^
// ^^^^^-match comma, restart match, then match optional space输出:
omc_playroom.id,omc_playroom.name,omc_playroom.parentid,omc_playroom.status,omc_playroom.table_id,omc_playroom.lang_idhttps://stackoverflow.com/questions/5448716
复制相似问题