找回密码
 注册账号

QQ登录

只需一步,快速开始

《泰拉瑞亚下载-1.4.2.3版》 泰拉瑞亚服务器 - MOD模组下载

入驻泰拉战网 新手指引 - 升级 - 师徒

泰拉瑞亚合成表 泰拉卡牌 - 泰拉江湖 - 泰拉刺客

联系泰拉开发组👈进入 积分市场 - 房产交易 - 水晶获取

查看: 2479|回复: 0

[原生PHP] php在数组中判断某个值是否存在,返回值或者键名

[复制链接]

262

主题

124

回帖

9

广播

业务站长

积分
166
泰拉
180
水晶
2
铜钥匙
0
银钥匙
0
金钥匙
0

【江湖新秀】【我是小土豪】【宝剑回鞘】【泰拉达人】【奥运选手】

发表于 2020-1-17 15:09:18 | 显示全部楼层 |阅读模式
本帖最后由 曲奇饼 于 2020-1-17 15:11 编辑

php在数组中查找指定值是否存在的方法有很多,记得很久以前我一直都是傻傻的用foreach循环来查找的,下面我主要分享一下用php内置的三个数组函数来查找指定值是否存在于数组中,这三个数组分别是
in_array(),
array_search(),
array_key_exists()。

首先分别介绍一下各自的定义与作用

in_array(value,array,type)
该函数的作用是在数组array中搜索指定的value值,type是可选参数,如果设置该参数为 true ,则检查搜索的数据与数组的值的类型是否相同,即恒等于(区分大小写)。
  1. <?php
  2. $people = array("Peter", "Joe", "Glenn", "Cleveland");
  3. if(in_array("Glenn",$people)){
  4.   echo "Match found";
  5. }else{
  6.   echo "Match not found";
  7. }
  8. ?>
  9. 输出:
  10. Match found
复制代码

array_key_exists(key,array)
该函数是判断某个数组array中是否存在指定的 key,如果该 key 存在,则返回 true,否则返回 false。
提示:请记住,如果您指定数组的时候省略了键名,将会生成从 0 开始并且每个键值对应以 1 递增的整数键名。
示例:
  1. <?php
  2. $a=array("a"=>"Dog","b"=>"Cat");
  3. if(array_key_exists("a",$a)){
  4. echo "Key exists!";
  5. }else{
  6. echo "Key does not exist!";
  7. }
  8. ?>
  9. 输出:
  10. Key exists!
复制代码

array_search(value,array,strict)
array_search() 函数与 in_array() 一样,在数组中查找一个键值。如果找到了该值,则返回匹配该元素所对应的键名。如果没找到,则返回 false。注意在 PHP 4.2.0 之前,函数在失败时返回 null 而不是 false。同样如果第三个参数 strict 被指定为 true,则只有在数据类型和值都一致时才返回相应元素的键名。
示例:
  1. <?php
  2. $a=array("a"=>"Dog","b"=>"Cat","c"=>5,"d"=>"5");
  3. echo array_search("Dog",$a);
  4. echo array_search("5",$a);
  5. ?>
  6. 输出:
  7. ad
复制代码


经过实际性能对比,在数据量不大的时候,比如小于1000,查找用哪一种都行,都不会成为性能上的瓶颈。但当数据量比较大的时候,用 array_key_exists 比较合适。据测试 array_key_exist 要比 in_array 效率高十几甚至几十倍。

获得 大怪兽卡 一张

卡片说明:曲奇饼 被 [凶猛的泰拉苦力怕] 袭击!逃跑时候掉落 21 泰拉.

卡片效果:损失 21 泰拉

慵懒~慵懒~
您需要登录后才可以回帖 登录 | 注册账号

本版积分规则

QQ|友链申请|Archiver|手机版|小黑屋|游芯沙盒 ( 陕ICP备11006283号-1 )

GMT+8, 2024-12-23 00:22 , Processed in 0.672563 second(s), 35 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表