Python中文
首页
教程
问答
标签
搜索
登录
注册
Python在if块或vice中定义函数
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<p>我有一个函数,我想根据模式采取不同的形式。我应该将定义包含在if语句中还是应该将if放在定义中?</p> <pre><code># Case 1 if mode == 1: def f(x): return x + 5 else: def f(x): return x - 5 # Case 2 def f(x): if mode == 1: return x + 5 else: return x - 5 </code></pre> <p>我在过去做过这两件事,我的静态代码分析工具似乎没有抱怨。所以我想知道是否有一个Python的建议?</p> <p>编辑:从目前的评论来看,这两种情况似乎都可以接受。这取决于用例。如果模式是恒定的,则首选情况1。如果不是,那么第二种情况。</p> <p>EDIT2:这个问题实际上是在我写函数的时候产生的。它将输入模式作为输入,并根据模式执行类似的操作,但它使用单独在函数中为这些操作定义的不同子函数。由于子函数在函数运行期间保持不变,情况1似乎更合适。</p> <p>编辑3:更正:在过去,我认为PyLint对案例1并不满意。这些天来,我使用了PyCharm,这似乎并没有表明案例1有任何问题。</p>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>您的函数行为不应依赖于外部值,因此我建议使用第一个示例:</p> <pre><code># Case 1 if mode == 1: def f(x): return x + 5 else: def f(x): return x - 5 </code></pre>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
将Pandas数据帧转换为PyTorch张量?
10 回答
将Pandas数据帧转换为scipy稀疏矩阵
2 回答
将Pandas数据帧转换为Spark Datafram时出现问题
8 回答
将pandas数据帧转换为spark DataFram时出错
9 回答
将Pandas数据帧转换为spark datafram时收到错误
9 回答
将Pandas数据帧转换为Spark数据帧
4 回答
将Pandas数据帧转换为Tensorflow数据
10 回答
将Pandas数据帧转换为tkinter obj
2 回答
将pandas数据帧转换为XML
1 回答
将Pandas数据帧转换为值sql语句
2 回答
将pandas数据帧转换为元组
9 回答
将pandas数据帧转换为元组列表
7 回答
将pandas数据帧转换为元组列表并删除所有pandas数据类型
5 回答
将pandas数据帧转换为具有头和数据类型的numpy数组
1 回答
将pandas数据帧转换为内存中的拼花地板,并将其加载到Python中的Hadoop中
10 回答
将pandas数据帧转换为内存中类似文件的对象?
7 回答
将Pandas数据帧转换为内存功能(&F)
7 回答
将pandas数据帧转换为列表列表
2 回答
将pandas数据帧转换为列表列表以输入到RNN
3 回答
将Pandas数据帧转换为单行DataFram
3 回答