我试图弄清楚如何处理我收到的数字范围的变化。我已经从数据帧中编译了它们,并尝试以100-200 / 200-300 / 300-400格式获取所有范围。
有时将输入为300.400,而不是300-400,有时将输入为300.5-400.5。如果可能的话,我还要考虑一下将它们输入为300.5.400.5的情况,因为有人可能会这样做,因为它是如此的疯狂。我想我可能应该尝试计划在它们之间没有出现“-”的任何字符。
为了简单起见,我想用小数点后的数字四舍五入,并用非“-”字符分隔范围,而不用小数点代替句点。
打扰一下我糟糕的代码:
num_range = [p.replace(' ', '') for p in num_dirty]
num_range = [p.replace(';', ' ') for p in num_dirty]
num_range = [p.replace('.', '-') for p in num_dirty]
num_clean = []
for r in num_dirty:
num_clean.append(r.split('/'))
num_clean = list(itertools.chain.from_iterable(num_clean))
num_clean = ','.join(num_clean)
我还使用在这里找到的此功能来列出频率范围内的所有数字,以便删除所有重复的范围:
num_lines = num_clean.split(',')
num_numbers = []
i = 0
for line in num_lines:
if line == '':
continue
elif '-' in line:
t = line.split('-')
num_numbers += range(int(t[0]), int(t[1]) + 1)
else:
num_numbers.append(int(line))
阿波罗的战车
相关分类