我正在尝试将值从0到15的数组重新分类为新的值从0到5。
我的情况如下:
con1 = np.in1d(arr, [0, 11, 13, 15]).reshape((y, x)) # new val 0
con2 = np.in1d(arr, [1, 2, 3, 4, 5]).reshape((y, x)) # new val 1
con3 = (arr == 6) | (arr == 7) # new val 2
con4 = (arr == 8) | (arr == 9) # new val 3
con5 = (arr == 10) # new val 4
con6 = (arr == 12) | (arr == 14) # new val 5
我在python中有以下一行
return np.where(con1, 0, np.where(con2, 1, np.where(con3, 2, np.where(con4, 3, np.where(con5, 4, np.where(con6, 5, arr))))))
,长度为128个字符(包括函数内的缩进)。 PEP8建议行不应超过79个字符。但是,我不确定在保持可读性的同时将该行拆分为多行的最佳方法是什么。
我尝试了两种选择,但它们似乎很难阅读。
选项1:
return np.where(con1, 0, np.where(
con2, 1, np.where(
con3, 2, np.where(
con4, 3, np.where(
con5, 4, np.where(
con6, 5, arr))))))
选项2:
return np.where(con1, 0,
np.where(con2, 1,
np.where(con3, 2,
np.where(con4, 3,
np.where(con5, 4,
np.where(con6, 5, arr)
)))))
答案 0 :(得分:4)
您可以单独完成所有操作。您可以按步骤进行操作,这样更具可读性。
filtered_result = np.where(con6, 5, arr)
filtered_result = np.where(con5, 4, filtered_result)
filtered_result = np.where(con4, 3, filtered_result)
filtered_result = np.where(con3, 2, filtered_result)
filtered_result = np.where(con2, 1, filtered_result)
filtered_result = np.where(con1, 0, filtered_result)
return filtered_result
要坚持使用pep8,这就是您要的方法,
修改
for循环还会显着减少重复性,并且仍然可读。
connections = iter((con6, con5, con4, con3, co2, con1, con0))
filters = range(len(connections)-2, 0 -1)
filtered_result = np.where(next(connections), next(filters), arr)
for n, con, in zip(filters, connections):
filtered_result = np.where(con, n, filtered_result)
return filtered_result
答案 1 :(得分:1)
可能可读性不强,但是您可以尝试reduce
:
from functools import reduce
def some_func():
... some code maybe ...
args = [con1, con2, con3, con4, con5, con6]
return reduce(
lambda prev_arg, new_arg: np.where(*new_arg, prev_arg),
enumerate(args[:-1]),
np.where(args[-1], len(args)-1, arr)
)