PHP 获取数组随意下标key的上一个prev和下一个next下标值

本文介绍了一种使用自定义类Steps来获取PHP数组中指定下标的前一个和后一个元素的方法。通过实例演示了如何创建Steps类并使用其方法来获取数组元素的前后下标。

PHP 获取数组随意下标key的上一个prev和下一个next下标值


<?

php $xoops[1] = '小'; $xoops[2] = '孩'; $xoops[3] = '子'; $xoops[4] = '气'; $steps = new Steps(); foreach($xoops as $key=>$value){ $steps->add($key); } $steps->setCurrent(3);//參数为key值 echo '上一个下标:'.$steps->getPrev()."<br />"; echo '指定的下标:'.$steps->getCurrent()."<br />"; echo '下一个下标:'.$steps->getNext()."<br />"; class Steps { private $all; private $count; private $curr; function __construct() { $this->count = 0; } function add($step) { $this->count++; $this->all[$this->count] = $step; } function setCurrent($step) { reset($this->all); for ($i = 1; $i <= $this->count; $i++) { if ($this->all[$i] == $step) break; next($this->all); } $this->curr = current($this->all); } function getCurrent() { return $this->curr; } function getNext() { self::setCurrent($this->curr); return next($this->all); } function getPrev() { self::setCurrent($this->curr); return prev($this->all); } }


打印结果:

上一个下标:2
指定的下标:3
下一个下标:4


转载于:https://www.cnblogs.com/mqxnongmin/p/10671604.html

在Python中,遍历一个数据结构(如列表、字典等)时,可以通过多种方式获取当前元素的前一个元素一个元素。以下是几种常见的方法: ### 方法一:使用索引 对于列表等有序数据结构,可以通过索引来获取一个元素一个元素。 ```python lst = [1, 2, 3, 4, 5] for i in range(len(lst)): prev_element = lst[i-1] if i > 0 else None next_element = lst[i+1] if i < len(lst)-1 else None print(f"当前元素: {lst[i]}, 前一个元素: {prev_element}, 后一个元素: {next_element}") ``` ### 方法二:使用`zip`函数 可以通过`zip`函数将列表与其自身偏移后的版本配对,从而获取一个元素一个元素。 ```python lst = [1, 2, 3, 4, 5] prev_elements = [None] + lst[:-1] next_elements = lst[1:] + [None] for current, prev, nxt in zip(lst, prev_elements, next_elements): print(f"当前元素: {current}, 前一个元素: {prev}, 后一个元素: {nxt}") ``` ### 方法三:使用迭代器`itertools` 对于更复杂的情况,可以使用`itertools`模块中的`tee`函数来创建两个独立的迭代器,一个用于前一个元素,一个用于后一个元素。 ```python from itertools import tee def pairwise(iterable): a, b = tee(iterable) next(b, None) return zip(a, b) lst = [1, 2, 3, 4, 5] for (prev, current), (current, nxt) in zip(pairwise(lst), pairwise(lst)[1:]): print(f"当前元素: {current}, 前一个元素: {prev}, 后一个元素: {nxt}") ``` ### 方法四:使用生成器 可以创建一个生成器函数来遍历列表并获取一个元素一个元素。 ```python def get_neighbors(lst): for i in range(len(lst)): prev_element = lst[i-1] if i > 0 else None next_element = lst[i+1] if i < len(lst)-1 else None yield lst[i], prev_element, next_element lst = [1, 2, 3, 4, 5] for item in get_neighbors(lst): print(f"当前元素: {item[0]}, 前一个元素: {item[1]}, 后一个元素: {item[2]}") ``` 这些方法都可以在遍历数据结构时获取当前元素的前一个元素一个元素。根据具体需求数据结构的不同,可以选择最适合的方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值