Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
Y
yii2
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
PSDI Army
yii2
Commits
57a6e8f3
Commit
57a6e8f3
authored
Jan 07, 2013
by
Qiang Xue
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Added ArrayHelper::sort()
parent
88672ed1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
29 additions
and
20 deletions
+29
-20
ArrayHelper.php
framework/util/ArrayHelper.php
+29
-20
No files found.
framework/util/ArrayHelper.php
View file @
57a6e8f3
...
@@ -218,29 +218,37 @@ class ArrayHelper
...
@@ -218,29 +218,37 @@ class ArrayHelper
}
}
/**
/**
* Searches the array for a given value and returns the corresponding key if found.
* Sorts a multi-dimensional array by a specific key.
* This method is similar to array_search() with the enhancement that it can also
* The multi-dimensional array can be either an array of arrays or an array of objects,
* search for strings in a case-insensitive manner.
* and the key can be a key name of the sub-arrays or a property name of the objects.
* @param mixed $needle the value being searched for
* @param array $items the multi-dimensional array to be sorted
* @param array $haystack the array to be searched through
* @param string|\Closure $key key name of the array element, or property name of the object,
* @param boolean $caseSensitive whether to perform a case-sensitive search
* or an anonymous function returning the value. The anonymous function signature should be:
* @param boolean $strict whether to perform a type-strict search
* `function($item)`.
* @return boolean|mixed the key of the value if it matches $needle. False if the value is not found.
* @param boolean $ascending whether to sort in ascending or descending order
* @param integer $sortFlag the PHP sort flag (e.g. `SORT_REGULAR`, `SORT_NUMERIC`.)
* See [PHP manual](http://php.net/manual/en/function.sort.php) for more details.
* @return array the sorted result. Note that the array will be re-indexed with integers.
*/
*/
public
static
function
s
earch
(
$needle
,
array
$haystack
,
$caseSensitive
=
true
,
$strict
=
true
)
public
static
function
s
ort
(
$items
,
$key
,
$ascending
=
true
,
$sortFlag
=
SORT_REGULAR
)
{
{
if
(
$caseSensitive
||
!
is_string
(
$needle
))
{
if
(
empty
(
$items
))
{
return
array_search
(
$needle
,
$haystack
,
$strict
)
;
return
$items
;
}
}
foreach
(
$haystack
as
$key
=>
$value
)
{
if
(
is_string
(
$value
))
{
foreach
(
$items
as
$k
=>
$item
)
{
if
(
strcasecmp
(
$value
,
$needle
)
===
0
)
{
$index
[
$k
]
=
static
::
getValue
(
$item
,
$key
);
return
true
;
}
}
elseif
(
$strict
&&
$key
===
$value
||
!
$strict
&&
$key
==
$value
)
{
return
true
;
}
}
}
return
false
;
if
(
$ascending
)
{
asort
(
$index
,
$sortFlag
);
}
else
{
arsort
(
$index
,
$sortFlag
);
}
$result
=
array
();
foreach
(
$index
as
$k
=>
$v
)
{
$result
[]
=
$items
[
$k
];
}
return
$result
;
}
}
}
}
\ No newline at end of file
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment