나는 여기서 어레이에서는 싶다 '와' 의 주요 검색하시겠습니까 uid 내려받습니다 어레이입니다.
2 치수 어레이입니다 solaris. 다음과 같습니다.
$userdb = array(
array(
'uid' => '100',
'name' => 'Sandra Shush',
'pic_square' => 'urlof100'
),
array(
'uid' => '5465',
'name' => 'Stefanie Mcmohn',
'pic_square' => 'urlof100'
),
array(
'uid' => '40489',
'name' => 'Michael',
'pic_square' => 'urlof40489'
)
);
함수 호출에 search_by_uid (100) '' () 는 사용자 1 안) '0' 반품하십시오.
이 함수 호출 (40489) '' 2 '' search_by_uid 반품해야 합니다.
하지만 난 로렌아줌마가 루프를 만드는 코드를 실행하는 속도가 찾았다.
function searchForId($id, $array) {
foreach ($array as $key => $val) {
if ($val['uid'] === $id) {
return $key;
}
}
return null;
}
이 작동합니다. 이와 같이 선고하게 합니다.
$id = searchForId('100', $userdb);
이해해야 할 수 있는 '=' 연산자입니다 추상형데이터타입 비해 사용하는 경우, 정확히 동일한 예제에서와 합니다 '=' 대신 '=' 검색 '또는' 문자열 됩니다.
$key = array_search('100', array_column($userdb, 'uid'));
(PHP 5 > = 5.5.0) 를 사용하는 경우, 자신의 기능을 쓸 수 없는, 그냥 이렇게 don& # 39 이 줄을 쓰기 및 it& # 39 의 수행되.
단 하나의 스케쳐내 결과:.
$key = array_search(40489, array_column($userdb, 'uid'));
여러 인스턴스용으로 결과
$keys = array_keys(array_column($userdb, 'uid'), 40489);
경우에 따라 abc. 가지고 있는 설명과 함께 연관 배열 (make it 수 있습니다.
$keys = array_keys(array_combine(array_keys($userdb), array_column($userdb, 'uid')),40489);
Php 를 사용하는 경우 <. 이 박포트 5.5.0 램지 바로 사용할 수 있습니다!
업데이트: # 39, ve been i& 몇 가지 간단한 벤치마크 결과 양식, 가장 빠른 것 같다고 할 수 있으며 여러 속도보다 훨씬 더 빠른 속도로 야쿠프 사용자 정의 함수!
function searcharray($value, $key, $array) {
foreach ($array as $k => $val) {
if ($val[$key] == $value) {
return $k;
}
}
return null;
}
사용법: '$ 결과 = 셰이크라이 (& # 39,, # 39 searchvalue& 시르코스키, $ array).'
Php (> = 5.5.0) 이 한 줄 광고문 이후 버전에서 사용할 수 있습니다.
$key = array_search('100', array_column($userdb, 'uid'));
하지만 난 이 확장 및 정보기술 (it) 이 이미 답변됨 그러니까말이야 사용할 수 있도록 좀 더 내 코드 검색, didn& # 39 만 uid 가 없다. 그냥 다른 사람들과 공유하고 싶어 하는 경우 해당 기능을 할 수 있습니다.
그리고 제발 내 예제에서와 here& # 39, 이것이 나의 첫 번째 대답을 베어 염두에 둔 것이다. 결국 나는 내가 경우 단 하나의 특정 매개변수 어레이입니다 아웃해야 검색할 수 있어 쉽게 추가할 수 있지만, 어레이입니다 기본적으로 단순히 uid 로 검색을 하고 싶었다.
또한, 내 상황이 있을 수 없는 다른 필드를 통해 검색 결과로 여러 키를 반환되기를 고유해야.
/**
* @param array multidimensional
* @param string value to search for, ie a specific field name like name_first
* @param string associative key to find it in, ie field_name
*
* @return array keys.
*/
function search_revisions($dataArray, $search_value, $key_to_search) {
// This function will search the revisions for a certain value
// related to the associative key you are looking for.
$keys = array();
foreach ($dataArray as $key => $cur_value) {
if ($cur_value[$key_to_search] == $search_value) {
$keys[] = $key;
}
}
return $keys;
}
나중에 알았지만 이 글을 쓰는 검색할 수 있도록 됐지 내가 다른 값을 연관적입니다 키. 그래서 제 값을 검색할 수 있는 첫 번째 예제는 특정 복귀하십시오 연관 키, 모든 경기에 출전하였다.
이 두 번째 예제에서와 값 (& # 39, Taylor& # 39;) 어디에 다른 값을 특정 키 (first_name) 및 연관 발견된다 (true) 는 다른 연관 키 (근로자) 에서 볼 수 있으며, 모든 되돌려줍니다 (키 # 39, & # 39, 첫 번째 이름 있는 사람들이 Taylor& 일치시킵니다 취업자 및 있다).
/**
* @param array multidimensional
* @param string $search_value The value to search for, ie a specific 'Taylor'
* @param string $key_to_search The associative key to find it in, ie first_name
* @param string $other_matching_key The associative key to find in the matches for employed
* @param string $other_matching_value The value to find in that matching associative key, ie true
*
* @return array keys, ie all the people with the first name 'Taylor' that are employed.
*/
function search_revisions($dataArray, $search_value, $key_to_search, $other_matching_value = null, $other_matching_key = null) {
// This function will search the revisions for a certain value
// related to the associative key you are looking for.
$keys = array();
foreach ($dataArray as $key => $cur_value) {
if ($cur_value[$key_to_search] == $search_value) {
if (isset($other_matching_key) && isset($other_matching_value)) {
if ($cur_value[$other_matching_key] == $other_matching_value) {
$keys[] = $key;
}
} else {
// I must keep in mind that some searches may have multiple
// matches and others would not, so leave it open with no continues.
$keys[] = $key;
}
}
}
return $keys;
}
$data = array(
array(
'cust_group' => 6,
'price' => 13.21,
'price_qty' => 5
),
array(
'cust_group' => 8,
'price' => 15.25,
'price_qty' => 4
),
array(
'cust_group' => 8,
'price' => 12.75,
'price_qty' => 10
)
);
$findKey = search_revisions($data,'8', 'cust_group', '10', 'price_qty');
print_r($findKey);
Array ( [0] => 2 )
나는 한 가지 수정되었음 아래에서 설명 함수 array_search. '모든' value (s) 의 주요 기능을 시치템즈비키 복귀하십시오 달러 가량 다차원 배열 (N 수준). 아마도 누군가를 유용할 것이다. 예:
$arr = array(
'XXX'=>array(
'YYY'=> array(
'AAA'=> array(
'keyN' =>'value1'
)
),
'ZZZ'=> array(
'BBB'=> array(
'keyN' => 'value2'
)
)
//.....
)
);
$result = searchItemsByKey($arr,'keyN');
print '<pre>';
print_r($result);
print '<pre>';
// OUTPUT
Array
(
[0] => value1
[1] => value2
)
function searchItemsByKey($array, $key)
{
$results = array();
if (is_array($array))
{
if (isset($array[$key]) && key($array)==$key)
$results[] = $array[$key];
foreach ($array as $sub_array)
$results = array_merge($results, searchItemsByKey($sub_array, $key));
}
return $results;
}
Array_filter 이 적합한 솔루션으로 될 것으로 보인다.
$userdb=Array
(
(0) => Array
(
(uid) => '100',
(name) => 'Sandra Shush',
(url) => 'urlof100'
),
(1) => Array
(
(uid) => '5465',
(name) => 'Stefanie Mcmohn',
(pic_square) => 'urlof100'
),
(2) => Array
(
(uid) => '40489',
(name) => 'Michael',
(pic_square) => 'urlof40489'
)
);
PHP 코드
<?php
$search = 5465;
$found = array_filter($userdb,function($v,$k) use ($search){
return $v['uid'] == $search;
},ARRAY_FILTER_USE_BOTH) // With latest PHP third parameter is mandatory.. Available Values:- ARRAY_FILTER_USE_BOTH OR ARRAY_FILTER_USE_KEY
$values= print_r(array_value($found));
$keys = print_r(array_keys($found));
비록 이것은 오래된 질문에 대한 대답을 한 수락됨 계시한하나님께 제안하세요 변경하십시오 수락됨 오토메이티드 한 것이라고 생각한다. 그래서 이 수락됨 답이 목마르겠구나 수정하십시오 first off, 동의합니다.
function searchArrayKeyVal($sKey, $id, $array) {
foreach ($array as $key => $val) {
if ($val[$sKey] == $id) {
return $key;
}
}
return false;
}
// Array Data Of Users
$userdb = array (
array ('uid' => '100','name' => 'Sandra Shush','url' => 'urlof100' ),
array ('uid' => '5465','name' => 'Stefanie Mcmohn','url' => 'urlof100' ),
array ('uid' => '40489','name' => 'Michael','url' => 'urlof40489' ),
);
// Obtain The Key Of The Array
$arrayKey = searchArrayKeyVal("uid", '100', $userdb);
if ($arrayKey!==false) {
echo "Search Result: ", $userdb[$arrayKey]['name'];
} else {
echo "Search Result can not be found";
}
[PHP 바이올린 예] [1]
[1]: http://phpfiddle.org/lite/code/8id5-m032 " php 바이올린 example";
I want to check 좁히어 & # 39 는 다음과 같은 어레이입니다 도착 '더' $ # 39 abc&;; 존재하는 것은 서브노드 어레이나
$arr = array(
array(
'title' => 'abc'
)
);
그럼 이 사용할 수 있습니다.
$res = array_search('abc', array_column($arr, 'title'));
if($res == ''){
echo 'exists';
} else {
echo 'notExists';
}
내 생각에 이것은 정의하십시오 가장 간단한 방법은
내가 가진 모든 기능을 사용할 수 있는 요소는 un aspt 어레이입니다. 그래서 내가 수정한 함수를 통해 수행됨 야쿠프 트루네체크 tpc. 다음과 같습니다.
function search_in_array_r($needle, $array) {
$found = array();
foreach ($array as $key => $val) {
if ($val[1] == $needle) {
array_push($found, $val[1]);
}
}
if (count($found) != 0)
return $found;
else
return null;
}
이 기능을 사용할 수 있습니다. https://github.com/serhatozles/ArrayAdvancedSearch
<?php
include('ArraySearch.php');
$query = "a='Example World' and b>='2'";
$Array = array(
'a' => array('d' => '2'),
array('a' => 'Example World','b' => '2'),
array('c' => '3'), array('d' => '4'),
);
$Result = ArraySearch($Array,$query,1);
echo '<pre>';
print_r($Result);
echo '</pre>';
// Output:
// Array
// (
// [0] => Array
// (
// [a] => Example World
// [b] => 2
// )
//
// )
/**
* searches a simple as well as multi dimension array
* @param type $needle
* @param type $haystack
* @return boolean
*/
public static function in_array_multi($needle, $haystack){
$needle = trim($needle);
if(!is_array($haystack))
return False;
foreach($haystack as $key=>$value){
if(is_array($value)){
if(self::in_array_multi($needle, $value))
return True;
else
self::in_array_multi($needle, $value);
}
else
if(trim($value) === trim($needle)){//visibility fix//
error_log("$value === $needle setting visibility to 1 hidden");
return True;
}
}
return False;
}
이 시도하시겠습니까
<?php
function recursive_array_search($needle,$haystack) {
foreach($haystack as $key=>$value) {
$current_key=$key;
if($needle===$value OR (is_array($value) &&
recursive_array_search($needle,$value) !== false)) {
return $current_key;
}
}
return false;
}
?>
그냥, 어쩌면 이렇게 공유할 수 있습니다.
if( ! function_exists('arraySearchMulti')){
function arraySearchMulti($search,$key,$array,$returnKey=false)
{
foreach ($array as $k => $val) {
if (isset($val[$key])) {
if ((string)$val[$key] == (string)$search) {
return ($returnKey ? $k : $val);
}
}else{
return (is_array($val) ? arraySearchMulti($search,$key,$val,$returnKey) : null);
}
}
return null;
}}
$search1 = 'demo';
$search2 = 'bob';
$arr = array('0' => 'hello','1' => 'test','2' => 'john','3' => array('0' => 'martin', '1' => 'bob'),'4' => 'demo');
foreach ($arr as $value) {
if (is_array($value)) {
if (in_array($search2, $value)) {
echo "successsfully";
//execute your code
}
} else {
if ($value == $search1) {
echo "success";
}
}
}
for( $i =0; $i < sizeof($allUsers); $i++)
{
$NEEDLE1='firstname';
$NEEDLE2='emailAddress';
$sterm='Tofind';
if(isset($allUsers[$i][$NEEDLE1]) && isset($allUsers[$i][$NEEDLE2])
{
$Fname= $allUsers[$i][$NEEDLE1];
$Lname= $allUsers[$i][$NEEDLE2];
$pos1 = stripos($Fname, $sterm);
$pos2=stripos($Lname, $sterm);//not case sensitive
if($pos1 !== false ||$pos2 !== false)
{$resultsMatched[] =$allUsers[$i];}
else
{ continue;}
}
}
Print_r($resultsMatched); //will give array for matched values even partially matched
코드 원 위에 도움을 받아 모든 데이터를 찾을 수 있습니다 (일부 매칭됨) 에서 필요에 따라 질문이예요 2D 어레이입니다 열에 그러하매 사용자 id 를 찾을 수 있습니다.
이 또한 시도하시겠습니까
function search_in_array($srchvalue, $array)
{
if (is_array($array) && count($array) > 0)
{
$foundkey = array_search($srchvalue, $array);
if ($foundkey === FALSE)
{
foreach ($array as $key => $value)
{
if (is_array($value) && count($value) > 0)
{
$foundkey = search_in_array($srchvalue, $value);
if ($foundkey != FALSE)
return $foundkey;
}
}
}
else
return $foundkey;
}
}
질문 경우 (예:
$a = [
[
"_id" => "5a96933414d48831a41901f2",
"discount_amount" => 3.29,
"discount_id" => "5a92656a14d488570c2c44a2",
],
[
"_id" => "5a9790fd14d48879cf16a9e8",
"discount_amount" => 4.53,
"discount_id" => "5a9265b914d488548513b122",
],
[
"_id" => "5a98083614d488191304b6c3",
"discount_amount" => 15.24,
"discount_id" => "5a92806a14d48858ff5c2ec3",
],
[
"_id" => "5a982a4914d48824721eafe3",
"discount_amount" => 45.74,
"discount_id" => "5a928ce414d488609e73b443",
],
[
"_id" => "5a982a4914d48824721eafe55",
"discount_amount" => 10.26,
"discount_id" => "5a928ce414d488609e73b443",
],
];
Ans.
function searchForId($id, $array) {
$did=0;
$dia=0;
foreach ($array as $key => $val) {
if ($val['discount_id'] === $id) {
$dia +=$val['discount_amount'];
$did++;
}
}
if($dia != '') {
echo $dia;
var_dump($did);
}
return null;
};
print_r(searchForId('5a928ce414d488609e73b443',$a));