在这个问题上我是 Python 的新手,我可能会使用一些不正确的术语并且会表现出误解 - 这就是我来这里的原因。
我正在研究 Python 函数,并试图确保我了解变量是如何传递和返回的。
我编写了这个简单的函数来对列表中的项目进行排序
def func_sort_list(NN):
for w in NN:
print (w, type(w))
NN.sort()
print (NN)
return (w)
我已经为列表赋值
unsort_letters=['q','w','e','r','t','y']
然后调用函数
func_sort_list(unsort_letters)
并得到结果
q <class 'str'>
w <class 'str'>
e <class 'str'>
r <class 'str'>
t <class 'str'>
y <class 'str'>
['e', 'q', 'r', 't', 'w', 'y']
'y'
然后,在执行之后,如果我显示我最初传递给我得到的函数的变量的内容
unsort_letters
['e', 'q', 'r', 't', 'w', 'y']
这是我想要的结果。
以下对发生的事情的解释是否正确,这样我在编写函数时会更有安全感?
unsort_letters ['q','w','e', ...] 的原始值是“全局”?
通过调用 func_sort_list(unsort_letters) 我已经将 unsort_letters 的地址/指针传递给 func_sort_list?
NN 是函数的“局部”变量,但它包含指向传递的变量的指针/地址,并且由于列表是可变的,unsort_letters 的内容是否在函数内更改?
这让我想到:
有没有这样的情况,我无法在函数中更改传递参数的内容,而我必须编写如下内容?
def func_return_only(input_parm):
result_var = << some processing on input_parm goes here>>
return (result_var)
我必须如下调用以获取 var_s 中返回值的值。
var_s = func_return_only(<< my input variable or value>>)
?
最佳答案
您的心智模型非常正确。但是,您不必担心 Python 是“按值传递”还是“按引用传递”。您必须了解 Python 中的赋值是如何工作的。 This是这样做的最佳资源。要知道的最重要的事实是赋值从不复制数据。
一旦你理解了赋值,你唯一需要知道的就是函数参数是通过赋值传递的。
调用函数时隐式发生的第一件事是
NN = unsort_letters
您传入了 unsort_letters 作为参数。您为该参数分配另一个 名称 (NN) - 仅此而已,不会复制任何数据。
Is there ever a circumstance when I cannot change the contents of the passed parameter within the function
是的,当你传入的任何东西都是不可变的。例如,整数没有更新其值的方法,因此您不能在函数体(或其他任何地方)中改变它们。
重要的是要注意,Python 在赋值和参数传递期间不会区别对待可变类型和不可变类型。您根本无法改变不可变类型,因为它们没有改变方法。
关于Python。参数和返回值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43204558/
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返
exe应该在我打开页面时运行。异步进程需要运行。有什么方法可以在ruby中使用两个参数异步运行exe吗?我已经尝试过ruby命令-system()、exec()但它正在等待过程完成。我需要用参数启动exe,无需等待进程完成是否有任何rubygems会支持我的问题? 最佳答案 您可以使用Process.spawn和Process.wait2:pid=Process.spawn'your.exe','--option'#Later...pid,status=Process.wait2pid您的程序将作为解释器的子进程执行。除
我有一些Ruby代码,如下所示:Something.createdo|x|x.foo=barend我想编写一个测试,它使用double代替block参数x,这样我就可以调用:x_double.should_receive(:foo).with("whatever").这可能吗? 最佳答案 specify'something'dox=doublex.should_receive(:foo=).with("whatever")Something.should_receive(:create).and_yield(x)#callthere
我正在为一个项目制作一个简单的shell,我希望像在Bash中一样解析参数字符串。foobar"helloworld"fooz应该变成:["foo","bar","helloworld","fooz"]等等。到目前为止,我一直在使用CSV::parse_line,将列分隔符设置为""和.compact输出。问题是我现在必须选择是要支持单引号还是双引号。CSV不支持超过一个分隔符。Python有一个名为shlex的模块:>>>shlex.split("Test'helloworld'foo")['Test','helloworld','foo']>>>shlex.split('Test"
我不确定传递给方法的对象的类型是否正确。我可能会将一个字符串传递给一个只能处理整数的函数。某种运行时保证怎么样?我看不到比以下更好的选择:defsomeFixNumMangler(input)raise"wrongtype:integerrequired"unlessinput.class==FixNumother_stuffend有更好的选择吗? 最佳答案 使用Kernel#Integer在使用之前转换输入的方法。当无法以任何合理的方式将输入转换为整数时,它将引发ArgumentError。defmy_method(number)
两者都可以defsetup(options={})options.reverse_merge:size=>25,:velocity=>10end和defsetup(options={}){:size=>25,:velocity=>10}.merge(options)end在方法的参数中分配默认值。问题是:哪个更好?您更愿意使用哪一个?在性能、代码可读性或其他方面有什么不同吗?编辑:我无意中添加了bang(!)...并不是要询问nobang方法与bang方法之间的区别 最佳答案 我倾向于使用reverse_merge方法:option
我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案
我有一个只接受一个参数的方法:defmy_method(number)end如果使用number调用方法,我该如何引发错误??通常,我如何定义方法参数的条件?比如我想在调用的时候报错:my_method(1) 最佳答案 您可以添加guard在函数的开头,如果参数无效则引发异常。例如:defmy_method(number)failArgumentError,"Inputshouldbegreaterthanorequalto2"ifnumbereputse.messageend#=>Inputshouldbegreaterthano
所以我开始关注ruby,很多东西看起来不错,但我对隐式return语句很反感。我理解默认情况下让所有内容返回self或nil但不是语句的最后一个值。对我来说,它看起来非常脆弱(尤其是)如果你正在使用一个不打算返回某些东西的方法(尤其是一个改变状态/破坏性方法的函数!),其他人可能最终依赖于一个返回对方法的目的并不重要,并且有很大的改变机会。隐式返回有什么意义?有没有办法让事情变得更简单?总是有返回以防止隐含返回被认为是好的做法吗?我是不是太担心这个了?附言当人们想要从方法中返回特定的东西时,他们是否经常使用隐式返回,这不是让你组中的其他人更容易破坏彼此的代码吗?当然,记录一切并给出