douya1061 2013-06-11 12:13
浏览 167
已采纳

在php中将字符串组合成一个数组

I have a web service to identify people and their functions from an external database that returns me a set of data if the login is successful. The data (that interests me right now) is separated in different strings as follow:

$groups="group1, group2, group3"
$functions="member, member, admin"

The first element of the string $groups corresponds to the first element of the $functions string.

We can have empty spots in the strings:

$groups="group1,, group3";
$functions="member,, admin";

What is the best way to combine them to obtain:

$usertype(
    group1=>member, 
    group2=>member, 
    group3=>admin,
);

Then I plan to use array_search() to get the name of the group that corresponds to a function.

  • 写回答

7条回答 默认 最新

  • dongyuchen9276 2013-06-11 12:15
    关注

    Have you tried a explode($delimiter , $string) and then filter the array? I think that would be a good way of doing it:

    $groups="group1,, group3";
    $functions="member,, admin";
    
    $groups_array = array_map('trim',explode(',', $groups));
    $functions_array = array_map('trim',explode(',', $functions));
    
    $final = array();
    for ($i = 0; $i <= count($groups_array); $i++) {
        $final[$groups_array[$i]] = $functions_array[$i];
    }
    
    $merged = array_combine($groups_array, $functions_array);
    

    Demo

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(6条)

报告相同问题?

悬赏问题

  • ¥15 宇视监控服务器无法登录
  • ¥15 PADS Logic 原理图
  • ¥15 PADS Logic 图标
  • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
  • ¥15 DruidDataSource一直closing
  • ¥20 气象站点数据求取中~
  • ¥15 如何获取APP内弹出的网址链接
  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
  • ¥50 STM32单片机传感器读取错误
  • ¥50 power BI 从Mysql服务器导入数据,但连接进去后显示表无数据