文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

PHP如何计算指定字符串在目标字符串中最后一次出现的位置

admin

admin

2024-04-02 19:55

关注

这篇文章将为大家详细讲解有关PHP如何计算指定字符串在目标字符串中最后一次出现的位置,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

PHP 中查找字符串最后一次出现的位置

PHP 提供了多种方法来查找字符串在目标字符串中最后一次出现的位置。

使用 strrpos() 函数

strrpos() 函数接受两个参数:目标字符串和要查找的字符串。它返回要查找的字符串在目标字符串中最后一次出现的位置的索引,如果字符串不存在,则返回 false。

<?php
$haystack = "Hello, world!";
$needle = "world";

$last_occurrence = strrpos($haystack, $needle);

if ($last_occurrence !== false) {
  echo "Last occurrence of "{$needle}" in "{$haystack}" is at position {$last_occurrence}.";
} else {
  echo "String not found.";
}
?>

使用 preg_match() 函数

preg_match() 函数使用正则表达式来查找字符串中的匹配项。要查找字符串的最后一次出现,可以使用 preg_match() 函数的 offset 参数。

<?php
$haystack = "Hello, world!";
$needle = "world";

$offset = 0;
$matches = [];

while (preg_match("/{$needle}/", $haystack, $matches, PREG_OFFSET_CAPTURE, $offset)) {
  $last_occurrence = $matches[0][1];
  $offset = $last_occurrence + 1;
}

if (isset($last_occurrence)) {
  echo "Last occurrence of "{$needle}" in "{$haystack}" is at position {$last_occurrence}.";
} else {
  echo "String not found.";
}
?>

使用 mb_strrpos() 函数

mb_strrpos() 函数与 strrpos() 函数类似,但它支持多字节字符串。对于包含非 ASCII 字符的字符串,这非常有用。

<?php
$haystack = "こんにちは、世界!";
$needle = "世界";

$last_occurrence = mb_strrpos($haystack, $needle);

if ($last_occurrence !== false) {
  echo "Last occurrence of "{$needle}" in "{$haystack}" is at position {$last_occurrence}.";
} else {
  echo "String not found.";
}
?>

使用 substr() 和 strrpos() 函数

另一种查找字符串最后一次出现的方法是使用 substr() 和 strrpos() 函数。substr() 函数可以提取字符串的一部分,而 strrpos() 函数可以查找指定字符串的最后一个出现。

<?php
$haystack = "Hello, world!";
$needle = "world";

$length = strlen($needle);
$last_occurrence = strrpos($haystack, $needle);

if ($last_occurrence !== false) {
  $start = $last_occurrence;
  $end = $last_occurrence + $length;
  $found_string = substr($haystack, $start, $end);

  echo "Last occurrence of "{$needle}" in "{$haystack}" is: {$found_string}";
} else {
  echo "String not found.";
}
?>

效率考虑

在效率方面,strrpos() 函数通常是查找字符串最后一次出现的最有效方法。preg_match() 和 mb_strrpos() 函数在处理复杂正则表达式或多字节字符串时可能速度较慢。

以上就是PHP如何计算指定字符串在目标字符串中最后一次出现的位置的详细内容,更多请关注编程网其它相关文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯