- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个 python(2.7) 类,它调用了一些 bash 命令。这里重要的是,期望下面调用的那些命令需要传递很多参数。这就是为什么我想允许在类的构造函数中设置这些参数,其过度简化如下所示:
def __init__(self, foo=None, baz=None, bar=None):
self._executor = BashExecutor()
self._foo = foo
self._baz = baz
self._bar = bar
此类还具有一些允许在一次 bash 执行范围内覆盖这些参数(但不强制执行)的函数。这意味着函数签名可以如下所示:
def execute(self, foo=None, baz=None, bar=None, sup=None):
然后是“有问题的部分”。每个参数都可以在函数范围内传递(在对象的构造函数中给出),也可以根本不传递(在函数中传递的优先级高于构造函数)。因此我有以下代码片段:
foo = foo or self._foo
if foo:
params.append(<<somehow formatted foo>>)
这些只有 3 行,但它们使用具有不同格式的不同参数重复了很多次......
这不能以某种方式简化吗?
说明该问题的完整示例如下所示:
class BashExecutor(object):
def execute(self, command):
print command
class Example(object):
def __init__(self, foo=None, baz=None, bar=None):
self._executor = BashExecutor()
self._foo = foo
self._baz = baz
self._bar = bar
def execute(self, foo=None, baz=None, bar=None, sup=None):
params = []
foo = foo or self._foo
if foo:
params.append("--foo_param %s" % foo)
baz = baz or self._baz
if baz:
params.append("--baz_param %s" % baz)
bar = bar or self._bar
if bar:
params.append("--additional_param bar=%s" % bar)
sup = sup or []
if sup:
params.append("--additional_param sup=%s" % ",".join(sup))
self._executor.execute("application %s" % " ".join(params))
ex = Example(foo=1, bar=2)
ex.execute(foo=3, sup=[ "abc", "def" ])
最佳答案
你可以这样做:
class Solution(object):
_ALLOWED_USER = ['cake', 'chocolate', 'creme_brulee']
_ALLOWED_VARS = ['broccoli', 'avocado', 'spinach']
def __init__(self, **kwargs):
self._validate_kwargs(kwargs)
for key, value in kwargs.iteritems():
setattr(self, '_{}'.format(key), value)
def _validate_kwargs(self, kwargs):
unrecognised = {key for key in kwargs if key not in self._ALLOWED_USER + self._ALLOWED_VARS}
if unrecognised:
raise ValueError('The following unrecognised arguments were passed: {}'.format(unrecognised))
def _populate(self, iterable, allowed, format_string):
result = []
for key in allowed:
attribute_name = '_{}'.format(key)
if key in iterable:
result.append(format_string.format(key, iterable[key]))
elif hasattr(self, attribute_name):
result.append(format_string.format(key, getattr(self, attribute_name)))
return result
def execute(self, **kwargs):
self._validate_kwargs(kwargs)
user_args = self._populate(kwargs, self._ALLOWED_USER, '--{}_param {}')
vars_args = self._populate(kwargs, self._ALLOWED_VARS, '--additional_param {}={}')
print(user_args + vars_args)
my_solution = Solution(cake='tasty', broccoli='icky', avocado='awesome')
my_solution.execute(creme_brulee='great', broccoli='okay, I guess', spinach='meh', cake='really tasty')
输出:
['--cake_param really tasty', '--creme_brulee_param great', '--additional_param broccoli=okay, I guess', '--additional_param avocado=awesome', '--additional_param spinach=meh']
您可以看到 cake
和 broccoli
的实例值已被传递给函数的值覆盖。
这个想法基本上是找出所有相关路径中不变的东西,并通过参数提供可定制性。通过将 user
参数与 vars
参数分离并使用 **kwargs
,我们可以灵活地实现输入验证和 每种类型的参数都有不同的输出。
参数覆盖实例变量的行为可以通过首先检查传递的参数中每个参数是否存在,然后使用 hasattr
检查实例的属性中是否存在来完成。
我现在无法访问 Python 2,但这应该可以工作。
关于python - 重构处理 "overrides of default parameters"的小代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56037044/
自从我开始工作(约 6 年)以来,我一直是 .NET 的一员。最近在做一个使用Django的项目,需要并行学习Python。很多时候我碰到的 Python 代码看起来很简单,但我就是看不懂。这是其中之
谁能解释一下 JLS §8.4.8.4 中提到的“严格的default-abstract 和default-default 冲突规则” . 它们是否在 JLS 中定义?我似乎找不到他们的定义。 最佳答
我在我的启动图像通用项目中添加了“Default.png,Default-568h@2x.png,Default@2x.png”这三个文件,我有三个不同的图像,分辨率与苹果中提到的完全相同文档,适用于
我试图在删除 AWS RDS MySQL 数据库后删除默认的数据库参数组,但出现以下错误 Failed to delete default.mysql8.0: Default DBParameterG
我想使用 firebase 云函数发送通知,所以我尝试使用 firebase.messaging().getToken() 获取 token ,但我不断收到错误消息: TypeError: fireb
无法通过 Instagram 登录我的应用。我正在使用 react-native instagram 包,但我面临这个问题,因为 _react3.default.creteRef() 不是一个函数。引
从 Rust 1.6 开始,当前特征 Default定义为, pub trait Default { fn default() -> Self; } 为什么不是这个 pub trait Def
在我的第一次代码审查(不久前)中,我被告知在所有 switch 语句中包含默认子句是一种很好的做法。我最近想起了这个建议,但不记得其理由是什么。现在对我来说听起来很奇怪。 始终包含默认语句是否有合理的
这个错误很奇怪。在 firebase 中 react native 有什么问题我已经通过 npm install 安装了 firebase这是我的代码 import React, {Component
对于以下 3 种编译情况: gcc -o helloc hello.c (1) g++ -o hellocpp hello.cpp
我有一个 switch 语句。它几乎可以正常工作,但是它不仅显示一个案例,还显示选定的案例,然后显示默认案例。这是我的代码: var people = { names: ["Sam", "Tim"
这个问题在这里已经有了答案: Default keyword in Swift parameter (1 个回答) 关闭 6 年前。 我试图理解前置条件函数并遇到了“= default”。快速谷歌和
禁止!配置的服务帐户无权访问。服务帐户可能已被撤销。用户“system:serviceaccount:default:default”无法获取命名空间“mycomp-services-process”
我一直在我的 React 中广泛使用命名导出和默认导出,我遇到了这 2 个相似的语法。 从'./Button'导出默认值; export { default } from './Button'; 有人
我很困惑什么时候使用 .prototype 来扩展一个对象,什么时候不使用它。像下面的部分代码,为什么不在FacebookApi.defaults中使用.prototype,难道.prototype只
这个问题在这里已经有了答案: What is the difference between "var=${var:-word}" and "var=${var:=word}"? (4 个答案) 关闭
我想创建一个数据类基类,其中子类中的所有字段都自动可选且默认为无(如果未提供默认值)。 下面的代码……几乎可以满足我的要求,但又不完全是。它出错的方式就像我从未编写过 __init_subclass_
所以我有三个 Typescript 文件: 配置/env/development.ts import { Config } from '../config'; class DevConfig {
我在一个名为 Activity 的表中添加了一个名为 Ordinal 的新列。问题是我给了它一个 UNIQUE 约束,将它设置为允许 NULL(尽管我最终不会想要这个。我只需要将它设置为那个以使脚本更
嗨,我是 struts2 的新手,在我的项目中,我在注册页面使用 json-default 扩展,并使用validation.xml 文件验证它,在同一个项目中,我在登录页面使用 struts-def
我是一名优秀的程序员,十分优秀!