欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP數(shù)組操作類實(shí)例

 更新時(shí)間:2015年07月11日 18:02:47   作者:mckee  
這篇文章主要介紹了PHP數(shù)組操作類,涉及php針對(duì)數(shù)組的刪除、轉(zhuǎn)換、分組、排序等相關(guān)操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下

本文實(shí)例講述了PHP數(shù)組操作類。分享給大家供大家參考。具體如下:

class ArrayHelper{
  /**
   * 從數(shù)組中刪除空白的元素(包括只有空白字符的元素)
   *
   * 用法:
   * @code php
   * $arr = array('', 'test', '  ');
   * ArrayHelper::removeEmpty($arr);
   *
   * dump($arr);
   *  // 輸出結(jié)果中將只有 'test'
   * @endcode
   *
   * @param array $arr 要處理的數(shù)組
   * @param boolean $trim 是否對(duì)數(shù)組元素調(diào)用 trim 函數(shù)
   */
  static function removeEmpty(& $arr, $trim = TRUE)
  {
    foreach ($arr as $key => $value)
    {
      if (is_array($value))
      {
        self::removeEmpty($arr[$key]);
      }
      else
      {
        $value = trim($value);
        if ($value == '')
        {
          unset($arr[$key]);
        }
        elseif ($trim)
        {
          $arr[$key] = $value;
        }
      }
    }
  }
  /**
   * 從一個(gè)二維數(shù)組中返回指定鍵的所有值
   *
   * 用法:
   * @code php
   * $rows = array(
   *   array('id' => 1, 'value' => '1-1'),
   *   array('id' => 2, 'value' => '2-1'),
   * );
   * $values = ArrayHelper::getCols($rows, 'value');
   *
   * dump($values);
   *  // 輸出結(jié)果為
   *  // array(
   *  //  '1-1',
   *  //  '2-1',
   *  // )
   * @endcode
   *
   * @param array $arr 數(shù)據(jù)源
   * @param string $col 要查詢的鍵
   *
   * @return array 包含指定鍵所有值的數(shù)組
   */
  static function getCols($arr, $col)
  {
    $ret = array();
    foreach ($arr as $row)
    {
      if (isset($row[$col])) {
        $ret[] = $row[$col];
      }
    }
    return $ret;
  }
  /**
   * 將一個(gè)二維數(shù)組轉(zhuǎn)換為 HashMap,并返回結(jié)果
   *
   * 用法1:
   * @code php
   * $rows = array(
   *   array('id' => 1, 'value' => '1-1'),
   *   array('id' => 2, 'value' => '2-1'),
   * );
   * $hashmap = ArrayHelper::toHashmap($rows, 'id', 'value');
   *
   * dump($hashmap);
   *  // 輸出結(jié)果為
   *  // array(
   *  //  1 => '1-1',
   *  //  2 => '2-1',
   *  // )
   * @endcode
   *
   * 如果省略 $valueField 參數(shù),則轉(zhuǎn)換結(jié)果每一項(xiàng)為包含該項(xiàng)所有數(shù)據(jù)的數(shù)組。
   *
   * 用法2:
   * @code php
   * $rows = array(
   *   array('id' => 1, 'value' => '1-1'),
   *   array('id' => 2, 'value' => '2-1'),
   * );
   * $hashmap = ArrayHelper::toHashmap($rows, 'id');
   *
   * dump($hashmap);
   *  // 輸出結(jié)果為
   *  // array(
   *  //  1 => array('id' => 1, 'value' => '1-1'),
   *  //  2 => array('id' => 2, 'value' => '2-1'),
   *  // )
   * @endcode
   *
   * @param array $arr 數(shù)據(jù)源
   * @param string $keyField 按照什么鍵的值進(jìn)行轉(zhuǎn)換
   * @param string $valueField 對(duì)應(yīng)的鍵值
   *
   * @return array 轉(zhuǎn)換后的 HashMap 樣式數(shù)組
   */
  static function toHashmap($arr, $keyField, $valueField = NULL)
  {
    $ret = array();
    if ($valueField)
    {
      foreach ($arr as $row)
      {
        $ret[$row[$keyField]] = $row[$valueField];
      }
    }
    else
    {
      foreach ($arr as $row)
      {
        $ret[$row[$keyField]] = $row;
      }
    }
    return $ret;
  }
  /**
   * 將一個(gè)二維數(shù)組按照指定字段的值分組
   *
   * 用法:
   * @endcode
   *
   * @param array $arr 數(shù)據(jù)源
   * @param string $keyField 作為分組依據(jù)的鍵名
   *
   * @return array 分組后的結(jié)果
   */
  static function groupBy($arr, $keyField)
  {
    $ret = array();
    foreach ($arr as $row)
    {
      $key = $row[$keyField];
      $ret[$key][] = $row;
    }
    return $ret;
  }
  /**
   * 將一個(gè)平面的二維數(shù)組按照指定的字段轉(zhuǎn)換為樹狀結(jié)構(gòu)
   *
   *
   * 如果要獲得任意節(jié)點(diǎn)為根的子樹,可以使用 $refs 參數(shù):
   * @code php
   * $refs = null;
   * $tree = ArrayHelper::tree($rows, 'id', 'parent', 'nodes', $refs);
   *
   * // 輸出 id 為 3 的節(jié)點(diǎn)及其所有子節(jié)點(diǎn)
   * $id = 3;
   * dump($refs[$id]);
   * @endcode
   *
   * @param array $arr 數(shù)據(jù)源
   * @param string $keyNodeId 節(jié)點(diǎn)ID字段名
   * @param string $keyParentId 節(jié)點(diǎn)父ID字段名
   * @param string $keyChildrens 保存子節(jié)點(diǎn)的字段名
   * @param boolean $refs 是否在返回結(jié)果中包含節(jié)點(diǎn)引用
   *
   * return array 樹形結(jié)構(gòu)的數(shù)組
   */
  static function toTree($arr, $keyNodeId, $keyParentId = 'parent_id', $keyChildrens = 'childrens', & $refs = NULL)
  {
    $refs = array();
    foreach ($arr as $offset => $row)
    {
      $arr[$offset][$keyChildrens] = array();
      $refs[$row[$keyNodeId]] =& $arr[$offset];
    }
    $tree = array();
    foreach ($arr as $offset => $row)
    {
      $parentId = $row[$keyParentId];
      if ($parentId)
      {
        if (!isset($refs[$parentId]))
        {
          $tree[] =& $arr[$offset];
          continue;
        }
        $parent =& $refs[$parentId];
        $parent[$keyChildrens][] =& $arr[$offset];
      }
      else
      {
        $tree[] =& $arr[$offset];
      }
    }
    return $tree;
  }
  /**
   * 將樹形數(shù)組展開為平面的數(shù)組
   *
   * 這個(gè)方法是 tree() 方法的逆向操作。
   *
   * @param array $tree 樹形數(shù)組
   * @param string $keyChildrens 包含子節(jié)點(diǎn)的鍵名
   *
   * @return array 展開后的數(shù)組
   */
  static function treeToArray($tree, $keyChildrens = 'childrens')
  {
    $ret = array();
    if (isset($tree[$keyChildrens]) && is_array($tree[$keyChildrens]))
    {
      foreach ($tree[$keyChildrens] as $child)
      {
        $ret = array_merge($ret, self::treeToArray($child, $keyChildrens));
      }
      unset($node[$keyChildrens]);
      $ret[] = $tree;
    }
    else
    {
      $ret[] = $tree;
    }
    return $ret;
  }
  /**
   * 根據(jù)指定的鍵對(duì)數(shù)組排序
   *
   * @endcode
   *
   * @param array $array 要排序的數(shù)組
   * @param string $keyname 排序的鍵
   * @param int $dir 排序方向
   *
   * @return array 排序后的數(shù)組
   */
  static function sortByCol($array, $keyname, $dir = SORT_ASC)
  {
    return self::sortByMultiCols($array, array($keyname => $dir));
  }
  /**
   * 將一個(gè)二維數(shù)組按照多個(gè)列進(jìn)行排序,類似 SQL 語(yǔ)句中的 ORDER BY
   *
   * 用法:
   * @code php
   * $rows = ArrayHelper::sortByMultiCols($rows, array(
   *   'parent' => SORT_ASC,
   *   'name' => SORT_DESC,
   * ));
   * @endcode
   *
   * @param array $rowset 要排序的數(shù)組
   * @param array $args 排序的鍵
   *
   * @return array 排序后的數(shù)組
   */
  static function sortByMultiCols($rowset, $args)
  {
    $sortArray = array();
    $sortRule = '';
    foreach ($args as $sortField => $sortDir)
    {
      foreach ($rowset as $offset => $row)
      {
        $sortArray[$sortField][$offset] = $row[$sortField];
      }
      $sortRule .= '$sortArray[\'' . $sortField . '\'], ' . $sortDir . ', ';
    }
    if (empty($sortArray) || empty($sortRule)) {
      return $rowset;
    }
    eval('array_multisort(' . $sortRule . '$rowset);');
    return $rowset;
  }
}

希望本文所述對(duì)大家的php程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • thinkphp備份數(shù)據(jù)庫(kù)的方法分享

    thinkphp備份數(shù)據(jù)庫(kù)的方法分享

    這篇文章主要介紹了thinkphp備份數(shù)據(jù)庫(kù)的方法分享,非常的簡(jiǎn)單實(shí)用,推薦給有需要的小伙伴們
    2015-01-01
  • PHP+Mysql基于事務(wù)處理實(shí)現(xiàn)轉(zhuǎn)賬功能的方法

    PHP+Mysql基于事務(wù)處理實(shí)現(xiàn)轉(zhuǎn)賬功能的方法

    這篇文章主要介紹了PHP+Mysql基于事務(wù)處理實(shí)現(xiàn)轉(zhuǎn)賬功能的方法,實(shí)例分析了mysql事務(wù)處理的使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-07-07
  • php中最簡(jiǎn)單的字符串匹配算法

    php中最簡(jiǎn)單的字符串匹配算法

    這篇文章主要介紹了php中最簡(jiǎn)單的字符串匹配算法,可實(shí)現(xiàn)簡(jiǎn)單的字符串查找與匹配位置顯示功能,是比較實(shí)用的字符串操作技巧,需要的朋友可以參考下
    2014-12-12
  • 使用PHPExcel操作Excel用法實(shí)例分析

    使用PHPExcel操作Excel用法實(shí)例分析

    這篇文章主要介紹了使用PHPExcel操作Excel用法,實(shí)例分析了使用PHPExcel進(jìn)行讀寫及生成等常用技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-03-03
  • php基于dom實(shí)現(xiàn)的圖書xml格式數(shù)據(jù)示例

    php基于dom實(shí)現(xiàn)的圖書xml格式數(shù)據(jù)示例

    這篇文章主要介紹了php基于dom實(shí)現(xiàn)的圖書xml格式數(shù)據(jù),結(jié)合實(shí)例形式分析了php數(shù)組轉(zhuǎn)換xml格式數(shù)據(jù)的相關(guān)操作技巧,需要的朋友可以參考下
    2017-02-02
  • 深入PHP curl參數(shù)的詳解

    深入PHP curl參數(shù)的詳解

    本篇文章是對(duì)PHP中的curl參數(shù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • PHP8使用Attributes管理代碼元數(shù)據(jù)的示例詳解

    PHP8使用Attributes管理代碼元數(shù)據(jù)的示例詳解

    在PHP 8中引入了一項(xiàng)強(qiáng)大的功能,即"Attributes"(屬性),它們提供了一種新的方法來(lái)管理和操縱代碼元數(shù)據(jù),Attributes允許你在代碼中添加元數(shù)據(jù),本文給大家介紹了在PHP8中是如何使用Attributes管理代碼元數(shù)據(jù),需要的朋友可以參考下
    2023-12-12
  • php中3des加密代碼(完全與.net中的兼容)

    php中3des加密代碼(完全與.net中的兼容)

    php中3des加密的結(jié)果與.Net/java不同的帖子與話題實(shí)在是太多了,我前不久也在倒騰這些,不過(guò)今天已經(jīng)搞定了,完全與.net中的兼容
    2012-08-08
  • 最新評(píng)論