我个人是很讨厌很多if-else, 或是switch case.
并不是说不好, 只是很容易出现有些section是code, 有些是function.
案子急一点, 重复的code就会很多.
几百个if-else/switch-case就有机会变成上万行的code. 这个就很阿杂了.
就之前数字区间的code, 我是会往这个方向走
import operator
def over_100m(s):
print('over 100m')
def ten_to_100m(s):
print('10 - 100m')
def zero_to_ten(s):
print('0 - 10')
def is_zero(s):
print('0')
def is_negative(s):
print('< 0')
map = {(operator.ge, 100000000): over_100m,
(operator.ge, 10): ten_to_100m,
(operator.gt, 0): zero_to_ten,
(operator.eq, 0): is_zero,
(operator.lt, 0): is_negative}
eigen_spectrum = [120000000, 1000, 10, 8, 0, -10]
for s in eigen_spectrum:
for c in map:
if c[0](s, c[1]):
map[c](s)
break
这样至少可以强迫分工的时候, 有一个列表可以作维护.
不过coding style这个真的见人见智, 我是不觉得有绝对好坏之分.