- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
这个slice(-1,0)
从一段实际代码中掉出来,它看起来几乎像一个切片换行,但事实并非如此。
评论:我怀疑实际的“切片包装”将是另一个挑战。
在“几乎包裹”切片的情况下,简单的解决方法是在这种特殊情况下删除上限:
AEIOU[-1:], AEIOU[-1:None], or (more quirkilly) AEIOU[-1:5]
更一般的尝试:(我正在使用:Python 2.6.6)
AEIOU[start%len(AEIOU): stop%len(AEIOU)] # simply struggles.
但是鉴于负成员函数 __getitem__
始终有效,“几乎包裹”的成员 __getslice__
只是返回太短的内容,这有点奇怪(危险) .
问题:
是否存在特定的设计原因导致“近包裹”切片较短,而不是(可能)引发IndexError:(列表/字符串/元组)索引超出范围”异常
?
如何创建列表的子类来管理它?
Python 3.0 中的处理方式是否有所不同?
演示:
>>> AEIOU="AEIOU"
>>> for i in range(-len(),5,1): print "%-16s, %r, %r"%(slice(i,i+1,1),AEIOU[i],AEIOU[i:i+1])
...
slice(-5, -4, 1), 'A', 'A'
slice(-4, -3, 1), 'E', 'E'
slice(-3, -2, 1), 'I', 'I'
slice(-2, -1, 1), 'O', 'O'
slice(-1, 0, 1) , 'U', '' # missing U...
slice(0, 1, 1) , 'A', 'A'
slice(1, 2, 1) , 'E', 'E'
slice(2, 3, 1) , 'I', 'I'
slice(3, 4, 1) , 'O', 'O'
slice(4, 5, 1) , 'U', 'U'
我注意到一般的“解决方法”是:
>>> i=-1; AEIOU[i:i%len(AEIOU)+1]
'U' # found U
勘误表,切片示例:
>>> s=3
>>> for i in range(-len(AEIOU),5,1): print "%-16s, %r, %r, %r"%(slice(i,i%len(AEIOU)+s,1),AEIOU[i],AEIOU[i:i+s], AEIOU[i:i%len(AEIOU)+s])
...
slice(-5, 3, 1) , 'A', 'AEI', 'AEI'
slice(-4, 4, 1) , 'E', 'EIO', 'EIO'
slice(-3, 5, 1) , 'I', '', 'IOU'
slice(-2, 6, 1) , 'O', '', 'OU'
slice(-1, 7, 1) , 'U', '', 'U'
slice(0, 3, 1) , 'A', 'AEI', 'AEI'
slice(1, 4, 1) , 'E', 'EIO', 'EIO'
slice(2, 5, 1) , 'I', 'IOU', 'IOU'
slice(3, 6, 1) , 'O', 'OU', 'OU'
slice(4, 7, 1) , 'U', 'U', 'U'
最佳答案
负索引从列表末尾开始倒数,但如果它们足够大,它们可能会超过开头。当它们超出范围时,它们只需固定到列表中的第一项即可。
items = range(10)
items[-10:-9]
# 0
items[-20:-9]
# 0
正索引从列表开头开始计数。如果超出范围,它们也会固定在列表末尾:
items[9:10]
#[9]
items[9:100]
#[9]
与常规的getitem访问不同,列表边界之外的索引只是被固定到末尾。通常这会返回一个空切片:
items[99:100]
#[]
items[-99:-88]
#[]
您的示例中出现特殊情况是因为 'aeiou'[-1:0]
与 'aeiou'[4:0]
相同 - 并且因为这是一个长度为负但步长为正的切片,因此它是空的。如果您输入 'aeiou'[4:0:-1]
,您将得到 'uoie'
。
由于固定行为,无法保证返回的切片将包含与说明符之间的距离相同数量的项目。切片是一个很好的习惯用法,可以在没有事先边界检查的情况下获取项目,这与我认为您所要求的相反:
stuff = ['a','b','c']
d = stuff[11:12]
# []
stuff[11]
#IndexError: list index out of range
如果您确实需要知道您的查询超出范围,您必须预先检查索引:
def strict_slice(the_list, begin, end):
listlen = len(the_list)
if begin > listlen or begin + listlen < 0:
raise IndexError, 'start index out of bounds'
if end + listlen < 0 or end > listlen:
raise IndexError, 'end index out of bounds'
return the_list[begin:end]
test = 'abcdefg'
strict_slice(test, 1, 3)
strict_slice(test, -10, 3)
# IndexError: start index out of bounds
strict_slice(test, 1, 20)
#IndexError: end index out of bounds
虽然您可以子类化 list
来执行此操作,但对我来说,使用此配方或仅检查空切片似乎更容易。
关于python - 通常只切片列表/元组的一个元素?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25049926/
我正在处理一组标记为 160 个组的 173k 点。我想通过合并最接近的(到 9 或 10 个组)来减少组/集群的数量。我搜索过 sklearn 或类似的库,但没有成功。 我猜它只是通过 knn 聚类
我有一个扁平数字列表,这些数字逻辑上以 3 为一组,其中每个三元组是 (number, __ignored, flag[0 or 1]),例如: [7,56,1, 8,0,0, 2,0,0, 6,1,
我正在使用 pipenv 来管理我的包。我想编写一个 python 脚本来调用另一个使用不同虚拟环境(VE)的 python 脚本。 如何运行使用 VE1 的 python 脚本 1 并调用另一个 p
假设我有一个文件 script.py 位于 path = "foo/bar/script.py"。我正在寻找一种在 Python 中通过函数 execute_script() 从我的主要 Python
这听起来像是谜语或笑话,但实际上我还没有找到这个问题的答案。 问题到底是什么? 我想运行 2 个脚本。在第一个脚本中,我调用另一个脚本,但我希望它们继续并行,而不是在两个单独的线程中。主要是我不希望第
我有一个带有 python 2.5.5 的软件。我想发送一个命令,该命令将在 python 2.7.5 中启动一个脚本,然后继续执行该脚本。 我试过用 #!python2.7.5 和http://re
我在 python 命令行(使用 python 2.7)中,并尝试运行 Python 脚本。我的操作系统是 Windows 7。我已将我的目录设置为包含我所有脚本的文件夹,使用: os.chdir("
剧透:部分解决(见最后)。 以下是使用 Python 嵌入的代码示例: #include int main(int argc, char** argv) { Py_SetPythonHome
假设我有以下列表,对应于及时的股票价格: prices = [1, 3, 7, 10, 9, 8, 5, 3, 6, 8, 12, 9, 6, 10, 13, 8, 4, 11] 我想确定以下总体上最
所以我试图在选择某个单选按钮时更改此框架的背景。 我的框架位于一个类中,并且单选按钮的功能位于该类之外。 (这样我就可以在所有其他框架上调用它们。) 问题是每当我选择单选按钮时都会出现以下错误: co
我正在尝试将字符串与 python 中的正则表达式进行比较,如下所示, #!/usr/bin/env python3 import re str1 = "Expecting property name
考虑以下原型(prototype) Boost.Python 模块,该模块从单独的 C++ 头文件中引入类“D”。 /* file: a/b.cpp */ BOOST_PYTHON_MODULE(c)
如何编写一个程序来“识别函数调用的行号?” python 检查模块提供了定位行号的选项,但是, def di(): return inspect.currentframe().f_back.f_l
我已经使用 macports 安装了 Python 2.7,并且由于我的 $PATH 变量,这就是我输入 $ python 时得到的变量。然而,virtualenv 默认使用 Python 2.6,除
我只想问如何加快 python 上的 re.search 速度。 我有一个很长的字符串行,长度为 176861(即带有一些符号的字母数字字符),我使用此函数测试了该行以进行研究: def getExe
list1= [u'%app%%General%%Council%', u'%people%', u'%people%%Regional%%Council%%Mandate%', u'%ppp%%Ge
这个问题在这里已经有了答案: Is it Pythonic to use list comprehensions for just side effects? (7 个答案) 关闭 4 个月前。 告
我想用 Python 将两个列表组合成一个列表,方法如下: a = [1,1,1,2,2,2,3,3,3,3] b= ["Sun", "is", "bright", "June","and" ,"Ju
我正在运行带有最新 Boost 发行版 (1.55.0) 的 Mac OS X 10.8.4 (Darwin 12.4.0)。我正在按照说明 here构建包含在我的发行版中的教程 Boost-Pyth
学习 Python,我正在尝试制作一个没有任何第 3 方库的网络抓取工具,这样过程对我来说并没有简化,而且我知道我在做什么。我浏览了一些在线资源,但所有这些都让我对某些事情感到困惑。 html 看起来
我是一名优秀的程序员,十分优秀!