2016-02-09 79 views
2

我有一個數組看起來像這樣在PHP排序關聯數組的鍵值

Array 
(
    [0] => Array 
     (
      [width] => 1 
      [ladiesSeat] => 
      [fare] => 610 
      [zIndex] => 0 
      [serviceTaxAmount] => 35.38 
      [commission] => 
      [operatorServiceChargeAbsolute] => 0 
      [operatorServiceChargePercent] => 0 
      [totalFareWithTaxes] => 645.38 
      [bookedBy] => 
      [ac] => 
      [sleeper] => 
      [serviceTaxPer] => 5.8 
      [available] => 1 
      [row] => 0 
      [column] => 2 
      [length] => 1 
      [id] => M1 
     ) 

    [1] => Array 
     (
      [width] => 1 
      [ladiesSeat] => 
      [fare] => 610 
      [zIndex] => 0 
      [serviceTaxAmount] => 35.38 
      [commission] => 
      [operatorServiceChargeAbsolute] => 0 
      [operatorServiceChargePercent] => 0 
      [totalFareWithTaxes] => 645.38 
      [bookedBy] => 
      [ac] => 
      [sleeper] => 
      [serviceTaxPer] => 5.8 
      [available] => 1 
      [row] => 1 
      [column] => 0 
      [length] => 1 
      [id] => L21 
     ) 
     ............... 
     ............... 
    [n] => Array 
     (
      [width] => 1 
      [ladiesSeat] => 
      [fare] => 610 
      [zIndex] => 0 
      [serviceTaxAmount] => 35.38 
      [commission] => 
      [operatorServiceChargeAbsolute] => 0 
      [operatorServiceChargePercent] => 0 
      [totalFareWithTaxes] => 645.38 
      [bookedBy] => 
      [ac] => 
      [sleeper] => 
      [serviceTaxPer] => 5.8 
      [available] => 1 
      [row] => 0 
      [column] => 0 
      [length] => 1 
      [id] => L21 
     ) 
) 

我要排序的基礎上按升序排列rowcolumn鍵的值數組。 這是預期的結果。

Array 
    (
     [0] => Array 
      (
       [width] => 1 
       [ladiesSeat] => 
       [fare] => 610 
       [zIndex] => 0 
       [serviceTaxAmount] => 35.38 
       [commission] => 
       [operatorServiceChargeAbsolute] => 0 
       [operatorServiceChargePercent] => 0 
       [totalFareWithTaxes] => 645.38 
       [bookedBy] => 
       [ac] => 
       [sleeper] => 
       [serviceTaxPer] => 5.8 
       [available] => 1 
       [row] => 0 
       [column] => 0 
       [length] => 1 
       [id] => M1 
      ) 

     [1] => Array 
      (
       [width] => 1 
       [ladiesSeat] => 
       [fare] => 610 
       [zIndex] => 0 
       [serviceTaxAmount] => 35.38 
       [commission] => 
       [operatorServiceChargeAbsolute] => 0 
       [operatorServiceChargePercent] => 0 
       [totalFareWithTaxes] => 645.38 
       [bookedBy] => 
       [ac] => 
       [sleeper] => 
       [serviceTaxPer] => 5.8 
       [available] => 1 
       [row] => 0 
       [column] => 2 
       [length] => 1 
       [id] => L21 
      ) 
      ............... 
      ............... 
     [n] => Array 
      (
       [width] => 1 
       [ladiesSeat] => 
       [fare] => 610 
       [zIndex] => 0 
       [serviceTaxAmount] => 35.38 
       [commission] => 
       [operatorServiceChargeAbsolute] => 0 
       [operatorServiceChargePercent] => 0 
       [totalFareWithTaxes] => 645.38 
       [bookedBy] => 
       [ac] => 
       [sleeper] => 
       [serviceTaxPer] => 5.8 
       [available] => 1 
       [row] => 1 
       [column] => 2 
       [length] => 1 
       [id] => L21 
      ) 
    ) 

即當我打印整理相關陣列 在rowcolumn鍵的值就應該是這樣的方式。

00 
02 
12 

那我該如何排序呢?

回答

1

爲便於閱讀,您可能需要清理一下這個功能,但該功能有點麻煩,但應該完成這項工作。任何問題都讓我知道。

function rowColumnSort($a, $b) { 
    // Row is lower. 
    if ($a['row'] < $b['row']) { 
     return -1; 
    } 

    // Rows Match, check columns 
    if ($a['row'] == $b['row']) { 
     // Column Higher 
     if ($a['column'] > $b['column']) { 
      return 1; 
     } else { 
      // Column lower 
      return -1; 
     } 
    } 

    // Row is higher 
    if ($a['row'] > $b['row']) { 
     return 1; 
    } 
} 

usort($arr, 'rowColumnSort'); 

實例應用:http://codepad.org/wyyqJCwg