在 Python 中,find 和 index 是非常相似的方法,用于查找序列类型中的值。 find 用于字符串,而 index 用于列表和元组。它们都返回找到提供的参数的最低索引(最左边的索引)。
例如,以下两个都将返回 1:
"abc".find("b")
[1,2,3].index(2)
但是,我有点困惑的是,尽管这两种方法非常相似,并且扮演着几乎相同的角色,只是对于不同的数据类型,它们对试图找到不在其中的东西的 react 却截然不同。顺序。
"abc".find("d")
返回-1,表示“未找到”,而
[1,2,3].index(4)
引发异常。
基本上,为什么他们有不同的行为?是有什么特殊原因,还是只是没有特殊原因的奇怪的不一致?
现在,我不是在问如何处理这个问题——显然,一个 try/except block ,或者一个条件 in 语句, 会工作。我只是在询问在特定情况下使行为不同的基本原理是什么。对我来说,为了一致性起见,将特定行为说为未找到更有意义。
另外,我并不是要就原因是否是一个好理由征求意见——我只是好奇是什么原因。
编辑: 有人指出字符串也有一个 index 方法,它的作用类似于列表的 index 方法,我'我承认我不知道,但这只是让我想知道为什么,如果字符串两者都有,列表只有 index。
最佳答案
这一直很烦人 ;-) 与一个答案相反,-1 就字符串而言并没有什么特别之处;例如,
>>> "abc"[-1]
'c'
>>> [2, 3, 42][-1]
42
find() 在实践中的问题在于 -1 实际上 not 作为索引是特殊的。因此,使用 find() 的代码在没有找到要搜索的东西时很容易出现意外——甚至在 Python 1.0.0 发布之前就已经注意到这样的代码经常会做错事。
当使用 index() 时不会发生这样的意外——异常不能被忽略。但是为这样一个简单的操作设置 try/except 不仅烦人,它还为“应该”快速操作增加了主要开销(额外时间)。因此,string.find() 在 Python 0.9.9 中被添加(在此之前,只能使用 string.index())。
所以我们两者都有,甚至在 Python 3 中仍然存在。选择你的毒药 :-)
关于Python - 为什么查找和索引方法的工作方式不同?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20410385/
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
我正在尝试设置一个puppet节点,但rubygems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由rubygems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
我想了解Ruby方法methods()是如何工作的。我尝试使用“ruby方法”在Google上搜索,但这不是我需要的。我也看过ruby-doc.org,但我没有找到这种方法。你能详细解释一下它是如何工作的或者给我一个链接吗?更新我用methods()方法做了实验,得到了这样的结果:'labrat'代码classFirstdeffirst_instance_mymethodenddefself.first_class_mymethodendendclassSecond使用类#returnsavailablemethodslistforclassandancestorsputsSeco
我试图获取一个长度在1到10之间的字符串,并输出将字符串分解为大小为1、2或3的连续子字符串的所有可能方式。例如:输入:123456将整数分割成单个字符,然后继续查找组合。该代码将返回以下所有数组。[1,2,3,4,5,6][12,3,4,5,6][1,23,4,5,6][1,2,34,5,6][1,2,3,45,6][1,2,3,4,56][12,34,5,6][12,3,45,6][12,3,4,56][1,23,45,6][1,2,34,56][1,23,4,56][12,34,56][123,4,5,6][1,234,5,6][1,2,345,6][1,2,3,456][123