php函数 二
一 字符串包含
1.1 str_starts_with(string $haystack, string $needle)
php8版本中新函数。
检查字符串是否以指定子串开头,区分大小写。返回布尔值。
$haystack待判断的字符串,$needle需要查询的内容。
function test1() {$str = "Qwe asd zxc 123";if (str_starts_with($str, '')) {echo __LINE__ . PHP_EOL; //5}if (str_starts_with($str, 'Qwe')) {echo __LINE__ . PHP_EOL; //8}if (str_starts_with($str, 'qwe')) {echo __LINE__ . PHP_EOL; //11}
}
test1();
测试结果
5
8
1.2 str_ends_with(string $haystack, string $needle)
php8版本中新函数。
检查字符串是否以指定子串结尾。返回布尔值。区分大小写。
$haystack待判断的字符串,$needle需要查询的内容。
function test3() {$str = "Qwe asd zxc 123 z";var_dump(str_ends_with($str, "Z"));var_dump(str_ends_with($str, "z"));var_dump(str_ends_with($str, "q"));var_dump(str_ends_with($str, "123"));
}
test3();
测试结果
bool(false)
bool(true)
bool(false)
bool(false)
1.3 strstr(string $haystack, string $needle, bool $before_needle = false)
查找字符串的首次出现。返回字符串或布尔值。区分大小写。
1.4 stristr(string $haystack, string $needle, bool $before_needle = false)
strstr()函数的忽略大小写版本。
function test4() {$str = "Qwe asd zxc 123 z";var_dump(strstr($str, "Qwe"));var_dump(strstr($str, "we"));var_dump(strstr($str, "we", true));var_dump(strstr($str, "q"));var_dump(stristr($str, "q"));
}
test4();
测试结果
string(17) "Qwe asd zxc 123 z"
string(16) "we asd zxc 123 z"
string(1) "Q"
bool(false)
string(17) "Qwe asd zxc 123 z"
1.5 strpos(string $haystack, string $needle, int $offset = 0)
查找字符串首次出现的位置。计算从零开始,也就是返回1,代表字符串中第二个位置;偏移到字符串第二个字符,偏移量是2。区分大小写。返回整数或者布尔值。
第一个字符返回值为0,应该使用0===$value判断。不存在返回false,应该使用false===$value判断。
$offset 为偏移量。
1.6 stripos(string $haystack, string $needle, int $offset = 0)
strpos()函数的忽略大小写版本。
function test5() {$str = "Qwe asd zxc 123 we";var_dump(strpos($str, "Qwe"));var_dump(strpos($str, "we"));var_dump(strpos($str, "we", 2));var_dump(strpos($str, "q"));var_dump(stripos($str, "WE"));
}
test5();
测试结果
int(0)
int(1)
int(16)
bool(false)
int(1)
1.7 strpbrk(string $string, string $characters)
在字符串中查找一组字符的任何一个字符。
返回以找到的字符开始的子字符串。如果没有找到,则返回 false。
$string 在string中查找characters字符串。
$characters 要查询的内容。区分大小写。
function test7() {$str = "Qwe asd zxc 123 we";$info = strpbrk($str, 'a');var_dump($info);$info = strpbrk($str, 'A');var_dump($info);
}
test7();
测试结果
string(14) "asd zxc 123 we"
bool(false)
1.8 preg_match()
执行匹配正则表达式。匹配到返回1,未匹配到返回0或者false。
参数
$pattern 正则表达式$subject需验证的字符串。 避免使用substr()。&$matches匹配结果$flags偏移量$offset开始搜索位置
$flags说明
PREG_OFFSET_CAPTURE附加偏移量PREG_UNMATCHED_AS_NULL使用该标记,未匹配的子组会报告为null;未使用时,报告为空的 string。
function test8() {$str = "Qwe asd zxc 123 we";$pattern = '/(?<=d).*(?=w)/';$result = preg_match($pattern, $str, $info, PREG_OFFSET_CAPTURE);var_dump($result);var_dump($info);$result = preg_match($pattern, $str, $info, PREG_OFFSET_CAPTURE, 8);var_dump($result);var_dump($info);
}
test8();
测试结果
int(1)
array(1) {[0]=>array(2) {[0]=>string(9) " zxc 123 "[1]=>int(7)}
}
int(0)
array(0) {
}
1.9 str_word_count(string $string, int $format = 0, ?string $characters = null)
返回字符串中单词的使用情况。返回数组或整数
如果指定了 format 参数,返回值将是一个数组,数组的内容则取决于 format 参数。
$format
- 0 返回单词数量
- 1 返回一个包含
string中全部单词的数组 - 2 返回关联数组。数组的键是单词在
string中出现的数值位置,数组的值是这个单词
$characters 附加的字符串列表,其中的字符将被视为单词的一部分。
function test9() {$str = "Qwe asd zxc 123 we";$info = str_word_count($str);var_dump($info);$info = str_word_count($str, 1);var_dump($info);$info = str_word_count($str, 0, "123456^ ^");var_dump($info);$info = str_word_count($str, 1, "123456^ ^");var_dump($info);$info = str_word_count($str, 2, "123456^ ^");var_dump($info);
}
test9();
测试结果
int(4)
array(4) {[0]=>string(3) "Qwe"[1]=>string(3) "asd"[2]=>string(3) "zxc"[3]=>string(2) "we"
}
int(1)
array(1) {[0]=>string(18) "Qwe asd zxc 123 we"
}
array(1) {[0]=>string(18) "Qwe asd zxc 123 we"
}
被操作的字符串中数字会被过滤掉,除非在$characters中添加数字或需最为单词的字符。
没发现$format 设置为1或2中区别。
二 字符串分割
2.1 explode(string $separator, string $string, int $limit = PHP_INT_MAX)
使用一个字符串分割另一个字符串。
$separator 分隔符
$string 字符串
$limit 限制数量。
正数返回从0开始的指定长度内容,最后一个值为字符串剩余部分。负数返回从末尾开始倒数的内容,直到数组开始,和substr长度的设置一个原理。传0视为1,返回包含整个字符串的数组。默认为内置常量PHP_INT_MAX,最大整数。无对应内容,返回包含整个字符串的数组。
function test6() {$str = "Qwe asd zxc 123 we";$arr2 = explode("W", $str);var_dump($arr2);$arr3 = explode(" ", $str, -2);var_dump($arr3);$arr1 = explode(" ", $str, 0);var_dump($arr1);$arr4 = explode(" ", $str, 1);var_dump($arr4);$arr5 = explode(" ", $str, 2);var_dump($arr5);
}
test6();
测试结果
array(1) {[0]=>string(18) "Qwe asd zxc 123 we"
}
array(3) {[0]=>string(3) "Qwe"[1]=>string(3) "asd"[2]=>string(3) "zxc"
}
array(1) {[0]=>string(18) "Qwe asd zxc 123 we"
}
array(1) {[0]=>string(18) "Qwe asd zxc 123 we"
}
array(2) {[0]=>string(3) "Qwe"[1]=>string(14) "asd zxc 123 we"
}
2.2 substr(string $string, int $offset, ?int $length = null)
返回字符串字串。字符串长度小于偏移量返回空字符串。
$offset 偏移量。
为正数从0开始计算。为负从尾开始计算,倒数指定的偏移量开始计算指定长度。
$length 指定长度。
为正数从offset处开始最多包括length个字符。最多返回到字符串结尾,即length大于字符串长度,返回到字符串结尾的长度。- 为0,返回空字符串
- 为null返回整个字符串
- 为负,那么
string末尾处的length个字符将会被省略。若offset是负数则从字符串尾部算起。如果offset不在这段文本中,那么将返回空字符串。
function test10() {$str = "Qwe asd zxc 123 we";$info = substr($str, 2);var_dump($info);$info = substr($str, 2, 2);var_dump($info);$info = substr($str, 2, 20);var_dump($info);$info = substr($str, -10, 2);var_dump($info);$info = substr($str, -10, 20);var_dump($info);$info = substr($str, 0);var_dump($info);
}
test10();
测试结果
string(16) "e asd zxc 123 we"
string(2) "e "
string(16) "e asd zxc 123 we"
string(2) "zx"
string(10) "zxc 123 we"
string(18) "Qwe asd zxc 123 we"
2.3 substr_count(string $haystack,string $needle,int $offset = 0,?int $length = null)
计算字串出现的次数。该函数返回 int。
在$haystack中查找$needle字符串。
$offset 偏移量。开始计数的偏移位置。如果是负数,就从字符的末尾开始统计。
$length 指定偏移位置之后的最大搜索长度。如果偏移量加上这个长度的和大于 haystack 的总长度,则打印警告信息。 负数的长度 length 是从 haystack 的末尾开始统计的。
function test11() {$str = "Qwe asd zxc 123 we";try{$info = substr_count($str, " ", 5, 5);var_dump($info);} catch (\Throwable $e) {var_dump($e->getTraceAsString());}try{$info = substr_count($str, " ", 5, 100);var_dump($info);} catch (\Throwable $e) {var_dump($e->getTraceAsString());}try{$info = substr_count($str, " ", -5, 5);var_dump($info);} catch (\Throwable $e) {var_dump($e->getTraceAsString());}try{$info = substr_count($str, " ", -5, 100);var_dump($info);} catch (\Throwable $e) {var_dump($e->getTraceAsString());}
}
test11();
测试结果
int(1)
string(117) "#0 D:\workspace\php\test\test12.php(130): substr_count()
#1 D:\workspace\php\test\test12.php(150): test11()
#2 {main}"
int(1)
string(117) "#0 D:\workspace\php\test\test12.php(144): substr_count()
#1 D:\workspace\php\test\test12.php(150): test11()
#2 {main}"
我本地php8版本,cache(\Exception $e){} 捕获不到异常……
相关文章:
php函数 二
一 字符串包含 1.1 str_starts_with(string $haystack, string $needle) php8版本中新函数。 检查字符串是否以指定子串开头,区分大小写。返回布尔值。 $haystack待判断的字符串,$needle需要查询的内容。 function test1() {$str "Qwe asd zx…...
IDC机房交换机核心技术与应用指南
IDC机房交换机核心技术与应用指南 在这个快速发展的数字时代,数据中心作为信息技术的心脏,不仅承载着海量数据的处理、存储和传输,更是支撑着全球企业运营和互联网服务的关键基础设施。在众多构成数据中心的组件中,IDC机房交换…...
Compose | UI组件(五) | Button 按钮组件
文章目录 前言Button 是什么?Button的创建Button显示水平方向的UI IconButton是什么?IconButton是创建 FloatingActionButton是什么?FloatingActionButton创建 ExtendedFloatingActionButton是什么? 总结 前言 随着移动端的技术不…...
【leetcode刷刷】235. 二叉搜索树的最近公共祖先 、701.二叉搜索树中的插入操作 、450.删除二叉搜索树中的节点
235. 二叉搜索树的最近公共祖先 class Solution:def lowestCommonAncestor(self, root: TreeNode, p: TreeNode, q: TreeNode) -> TreeNode:# 递归if not root: return if root.val p.val: return pif root.val q.val: return qleft Noneright Noneif root.val > p.…...
YoloV8改进策略:BackBone改进|DCNv4最新实践|高效涨点|多种改进教程|完整论文翻译
摘要 涨点效果:在我自己的数据集上,mAP50 由0.986涨到了0.993,mAP50-95由0.737涨到0.77,涨点明显! DCNv4是可变形卷积的第四版,速度和v3相比有了大幅度的提升,但是环境搭建有一定的难度,对新手不太友好。如果在使用过程遇到编译的问题,请严格按照我写的环境配置。 …...
高中数学常识
一、大小关系 |x| > |sinx| 理由: 很明显,在圆内,弧长x>垂线sinx 3x、2x 、 1 2 \frac{1}{2} 21x 理由: log 1 2 _\frac{1}{2} 21x、log 2 _2 2x、 log 3 _3 3x 二、(xy)? 的求法 利用二项式定理 三、平…...
docker之部署青龙面板
青龙面板是一个用于管理和监控 Linux 服务器的工具,具有定时运行脚本任务的功能。在实际情况下也可以用于一些定期自动签到等任务脚本的运行。 本次记录下简单的安装与使用,请提前安装好docker,参考之前的文章。 一、安装部署 1、拉取镜像 # …...
Type-C平板接口协议芯片介绍,实现单C口充放电功能
在现代平板电脑中,Type-C接口已经成为了一个非常常见的接口类型。相比于传统的USB接口,Type-C接口具有更小的体积、更快的传输速度和更方便的插拔体验。但是,在使用Type-C接口的平板电脑上,如何实现单C口充电、放电和USB2.0数据传…...
系统架构演变
1.1系统架构的演变 2008年以后,国内互联网行业飞速发展,我们对软件系统的需求已经不再是过去”能用就行”这种很low的档次了,像抢红包、双十一这样的活动不断逼迫我们去突破软件系统的性能上限,传统的IT企业”能用就行”的开发思…...
Oracle PL/SQL Programming 第2章:Creating and Running PL/SQL Code 读书笔记
总的目录和进度,请参见开始读 Oracle PL/SQL Programming 第6版 暂不考虑系统设计或单元测试之类的任务,所有 PL/SQL 程序员必须熟悉的基本操作任务包括: 浏览数据库创建和编辑 PL/SQL 源代码编译 PL/SQL 源代码,并更正编译器注…...
鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之Swiper容器组件
鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之Swiper容器组件 一、操作环境 操作系统: Windows 10 专业版、IDE:DevEco Studio 3.1、SDK:HarmonyOS 3.1 二、Swiper容器组件 滑块视图容器,提供子组件滑动轮播显示的能力。…...
『建议收藏』OpenAI官方出的Prompt提示词教程中文版来了!
一些结论 六大策略: 写清晰的指令 提供参考文本 将复杂任务分解为更简单的子任务 给模型时间“思考” 使用外部工具 系统性测试变化 提高结果质量的六大策略 写清晰的指令 这些模型无法读懂你的想法。如果输出过长,要求简短回复;如果输出过于简单…...
牛刀小试 - C++ 推箱子小游戏
参考文档 C笔记:推箱子小游戏 copy函数 memcpy()函数用法(可复制数组) 使用memcpy踩出来的坑,值得注意 完整代码 /********************************************************************* 程序名:推箱子小游戏 说明&#x…...
手机视频压缩怎么压缩?一键瘦身~
现在手机已经成为我们日常生活中必不可少的工具,而在手机的应用领域中,文件的传输和存储是一个非常重要的问题。很多用户都会遇到这样一个问题,那就是在手机上存储的文件太多太大,导致手机存储空间不足,那么怎么在手机…...
目标主力能源:华为智能光伏的时代指南针
让新能源成为人类主要的能源来源,是实现“双碳目标”的核心方案。而光伏能源则是目前新能源体系中的主要选择之一。以光伏为核心构建新型电力系统,让光伏能源成为主力能源值得关注和期待。 过去几年,光伏能源极速发展。但如何百尺竿头更进一步…...
每日一题 力扣2846 边权重均等查询
2846. 边权重均等查询 题目描述: 现有一棵由 n 个节点组成的无向树,节点按从 0 到 n - 1 编号。给你一个整数 n 和一个长度为 n - 1 的二维整数数组 edges ,其中 edges[i] [ui, vi, wi] 表示树中存在一条位于节点 ui 和节点 vi 之间、权重…...
【Docker】Docker学习⑨ - 单机编排之Docker Compose
【Docker】Docker学习⑨ - 单机编排之Docker Compose 一、Docker简介二、Docker安装及基础命令介绍三、Docker镜像管理四、Docker镜像与制作五、Docker数据管理六、网络部分七、Docker仓库之单机Dokcer Registry八、Docker仓库之分布式Harbor九、单机编排之Docker Compose1 基础…...
ES6笔记-symbol
ES6 symbol 是什么 ES5的对象属性名是字符串,这容易造成属性名的冲突。symbol是一种机制,保证每个属性的名字都是独一无二的。这样就从根本上防止属性名冲突。 它是一种原始数据类型Symbol,表示独一无二的值。它属于javaScript语言的原生数据类型之一。…...
C++设计模式介绍:优雅编程的艺术
物以类聚 人以群分 文章目录 简介为什么有设计模式? 设计模式七大原则单一职责原则(Single Responsibility Principle - SRP)开放封闭原则(Open/Closed Principle - OCP)里氏替换原则(Liskov Substitution …...
GitLab升级版本(任意用户密码重置漏洞CVE-2023-7028)
目录 前言漏洞分析影响范围查看自己的GitLab版本升级路程 升级过程13.1.1113.8.8 - 14.0.1214.3.614.9.5 - 16.1.6 前言 最近GitLab发了个紧急漏洞需要修复,ok接到命令立刻着手开始修复,在修复之前先大概了解一下这个漏洞是什么东西 漏洞分析 1、组件…...
MyBatis批量更新避坑指南:从`<foreach>`拼接SQL到`allowMultiQueries`配置的完整流程
MyBatis批量更新实战:从基础实现到性能调优全解析 批量更新操作是后端开发中绕不开的高频需求,但很多开发者在初次接触MyBatis批量更新时,往往会陷入各种"坑"中。本文将带你系统掌握两种主流实现方案,从基础用法到性能优…...
YOLOv8鹰眼目标检测问题解决:常见部署错误与使用技巧汇总
YOLOv8鹰眼目标检测问题解决:常见部署错误与使用技巧汇总 1. 引言:为什么选择YOLOv8鹰眼目标检测 YOLOv8作为当前计算机视觉领域最先进的目标检测模型之一,以其卓越的实时性和准确性赢得了广泛认可。鹰眼目标检测镜像基于Ultralytics官方YO…...
百川2-13B模型实战:Python爬虫数据的智能分析与摘要生成
百川2-13B模型实战:Python爬虫数据的智能分析与摘要生成 每天,互联网上都会产生海量的文本信息,新闻、论坛帖子、社交媒体动态……对于市场分析师、舆情监控人员或者内容运营者来说,如何从这些信息海洋中快速提炼出有价值的内容&…...
FlowState Lab结合计算机网络概念:模拟智能网络配置助手
FlowState Lab结合计算机网络概念:模拟智能网络配置助手 1. 网络运维的痛点与AI解决方案 网络工程师每天都要面对复杂的网络环境和层出不穷的故障问题。传统排错流程往往需要工程师手动检查设备配置、分析日志信息、查阅技术文档,这个过程耗时耗力且容…...
AMD显卡专属优化:Ollama-for-amd本地大模型部署终极指南
AMD显卡专属优化:Ollama-for-amd本地大模型部署终极指南 【免费下载链接】ollama-for-amd Get up and running with Llama 3, Mistral, Gemma, and other large language models.by adding more amd gpu support. 项目地址: https://gitcode.com/gh_mirrors/ol/ol…...
PHPBrew终极性能优化指南:10个技巧加速PHP编译安装
PHPBrew终极性能优化指南:10个技巧加速PHP编译安装 【免费下载链接】phpbrew Brew & manage PHP versions in pure PHP at HOME 项目地址: https://gitcode.com/gh_mirrors/ph/phpbrew PHPBrew是一款纯PHP编写的PHP版本管理工具,能够帮助开发…...
探索声发射 b 值:Matlab 程序之旅
声发射b值,Matlab程序在材料科学和岩石力学等领域,声发射(Acoustic Emission,AE)技术是研究材料内部损伤演化的重要手段。而声发射 b 值作为其中一个关键参数,能反映材料内部微破裂的特征。今天,…...
VSCode插件离线安装的隐藏技巧:如何批量安装.vsix文件提升效率
VSCode插件离线批量安装实战指南:企业级效率提升方案 在团队协作或企业内网环境中,开发者常面临VSCode插件安装的困境——无法访问官方市场、重复下载耗时、版本管理混乱。传统单个.vsix文件安装方式在需要部署数十个插件时,效率低下到令人抓…...
频繁冲突?数据静默损坏?Obsidian + 坚果云插件打造工业级笔记同步与容灾方案
在个人知识管理(PKM)领域,有一条铁律:比“从未备份”更可怕的,是“错误的同步导致的静默覆盖”。 对于 Obsidian 重度用户而言,几千篇 Markdown 笔记是毕生心血。当你兴冲冲地在手机、iPad 和公司电脑之间…...
别再手动推导了!用Sophus库5分钟搞定机器人SLAM中的位姿插值与扰动更新
别再手动推导了!用Sophus库5分钟搞定机器人SLAM中的位姿插值与扰动更新 在机器人SLAM开发中,你是否曾为手动推导旋转矩阵的插值公式而抓狂?是否在实现位姿扰动更新时被四元数微分弄得晕头转向?今天,我们将用Sophus库彻…...
