suchen

Heim  >  Fragen und Antworten  >  Hauptteil

Der PHP-Master befasst sich mit einem Array-Problem

        [['7','2'],['8','2'],['11','2'],['10','2'],['9','2']]

Der Datenbestand sieht folgendermaßen aus: ['7','2'] 7 steht für die Produkt-ID und 2 für die Menge des gekauften Produkts

Wie kann man es nun in einem Array wiederherstellen, das von PHP verwendet werden kann?

高洛峰高洛峰2729 Tage vor848

Antworte allen(7)Ich werde antworten

  • 滿天的星座

    滿天的星座2017-06-08 11:03:38

    属于偷鸡取巧的方法:当然,前提是你的数据都是完整的,不会有负数,NULL什么的

    $a = "[['7','2'],['8','2'],['11','2'],['10','2'],['9','2']]";
    $result = array();
    preg_match_all("/'(\d*)'/", $a, $matches);
    for ($i = 0; $i < count($matches[1]); $i += 2){
       $result[(int)$matches[1][$i]] = (int) $matches[1][$i+1];
    }

    亲测成功

    Antwort
    0
  • 大家讲道理

    大家讲道理2017-06-08 11:03:38

    你没说具体格式,我就先采用下面这种格式了

    $data = [['7','2'],['8','2'],['11','2'],['10','2'],['9','2']];
    $products = array();
    foreach ($data as $tmp) {
        $products[] = array(
            'id' => $tmp[0],
            'total' => $tmp[1]
        );
    }
    var_dump($products);

    Antwort
    0
  • 淡淡烟草味

    淡淡烟草味2017-06-08 11:03:38

    谢邀!

    你这个就是数组,你直接循环好了:

        $arr     = [['7','2'],['8','2'],['11','2'],['11','2'],['11','2']];
        var_dump($arr[0]);die;
        

    这个数组等同于:

        $arr     = array(
                        array('7','2'),
                        array('8','2'),
                        array('11','2'),
                        array('11','2'),
                        array('11','2'),
                    );
         var_dump($arr[0]);die;

    Antwort
    0
  • phpcn_u1582

    phpcn_u15822017-06-08 11:03:38

    你这么存进去的,再反解回来不就结了么。

    $str = json_encode(array(
        array(7, 2),
        array(8, 2),
    ));
    
    var_dump(json_decode($str));

    Antwort
    0
  • 迷茫

    迷茫2017-06-08 11:03:38

    标准json需要双引号, 所以只要把单引号转成双引号, 再json_decode

    $sqldata = "[['7','2'],['8','2'],['11','2'],['10','2'],['9','2']]";
    $sqldata = str_replace('\'', '\"', $sqldata );
    $data = json_decode($sqldata);
    echo $data[0][1]; // >> 2

    Antwort
    0
  • 女神的闺蜜爱上我

    女神的闺蜜爱上我2017-06-08 11:03:38

    $str = "[['7','2'],['8','2'],['11','2'],['10','2'],['9','2']]";
    var_dump(eval('return '.$str.';'));

    试试

    Antwort
    0
  • 三叔

    三叔2017-06-08 11:03:38

    json_decode() 

    Antwort
    0
  • StornierenAntwort