gpt4 book ai didi

python - 在Python中使用数组以更方便的方式编写长switch语句

转载 作者:行者123 更新时间:2023-11-30 23:21:06 25 4
gpt4 key购买 nike

我已经检查了以下答案: Replacements for switch statement in Python?How to refactor Python "switch statement"

但我认为两者都指的是具有单一情况的更简单的 switch 语句。

我遇到一个问题,switch 语句看起来像这样:

switch(view) {
case "negatives":
label = 0;
break;
case "cars\\00inclination_000azimuth":
case "buses\\00inclination_000azimuth":
case "trucks\\00inclination_000azimuth":
label = 1;
break;
case "cars\\00inclination_045azimuth":
case "buses\\00inclination_045azimuth":
case "trucks\\00inclination_045azimuth":
case "cars\\00inclination_090azimuth":
case "buses\\00inclination_090azimuth":
case "trucks\\00inclination_090zimuth":
case "cars\\00inclination_135azimuth":
case "buses\\00inclination_135azimuth":
case "trucks\\00inclination_135azimuth":
label = 2;
break;
# and so on

所以有很多情况会导致相同的标签。有没有一种快速的方法可以使用列表来做到这一点?我可以在哪里使用这样的东西

a = ["cars\\00inclination_045azimuth","buses\\00inclination_045azimuth","trucks\\00inclination_045azimuth","cars\\00inclination_090azimuth","buses\\00inclination_090azimuth", "trucks\\00inclination_090zimuth","cars\\00inclination_135azimuth","buses\\00inclination_135azimuth","trucks\\00inclination_135azimuth"]

if view in a:
label = 2

但是我必须为映射到相同标签的每组案例制作一个列表,然后遍历每个案例。

有没有办法执行以下操作,如果没有,那么最简单的方法是什么?

 if view in _any_of_the_lists_i've_made:
label = the_index_of_that_list

更新

我在问题中显示的值只是其中的一些,以便对问题有一个总体了解。但我从一些评论中意识到,最好以案例的形式给出我所拥有的全部值(value)观。

  • 有 3 个前缀:“汽车”、“卡车”和“巴士”。
  • 有 4 个倾斜角(斜线后的前两位数字)。所以我可以有 cars\00inclination_000azimuth,或 cars\30inclination_000azimuth 或 cars\60inclination_000azimuth 或 cars\90inclination_000azimuth
  • 共有 25 个不同的方位角。由于相差 45 度,所以我可以将 cars\00inclination_000azimuth 和 cars\00inclination_045azimuth 一直到 cars\00inclination_315azimuth

因此,每辆车总共有 25 个 View ,对于 3 辆车,有 75 种不同的可能 View ,即 75 种情况。

最佳答案

您的 View 字符串遵循某种模式;它们包括 <transport>\<inclination>_<azimuth> ,并且您的标签仅在方位角值上有所不同。

将字符串缩减为方位角值,然后使用 dict找到您的标签:

labels = {'000': 1, '045': 2, '090': 2, '135': 2}

label = 0 if view == 'negatives' else labels[view.rpartition('_')[-1][:3]]

azimuth 中取出 3 位数字。字符串。

为了说明其工作原理,请看一个简短的演示:

>>> "cars\\00inclination_000azimuth".rpartition('_')
('cars\\00inclination', '_', '000azimuth')
>>> "cars\\00inclination_000azimuth".rpartition('_')[-1]
'000azimuth'
>>> "cars\\00inclination_000azimuth".rpartition('_')[-1][:3]
'000'

str.rpartition() 最后 split _字符,从中我们选择最后一个元素,然后从最后一个元素中我们切片前 3 个字符。

如果您也需要根据倾向进行变化,请单独解析:

labels = {
None: 0,
('00', '000'): 1,
('00', '045'): 2,
('00', '090'): 2,
('00', '135'): 2,
# etc.
}

if view == 'negatives':
key = None
else:
key = view.partition('\\')[-1][:2], view.rpartition('_')[-1][:3]
label = labels[key]

通过将 View 减少到只保留那些重要的部分,您可以大大减小字典的大小,或者至少您需要键入的部分

当然,直接查找 View 字符串会更快。您始终可以从上述字典生成完整字符串:

for key, label in labels.items():
if key is None:
labels['negatives'] = label
continue
for vehicle in ('cars', 'trucks', 'buses'):
labels['{}\\{}inclination_{}azimuth'.format(vehicle, *key)] = label

然后直接查找你的标签:

label = labels[view]

关于python - 在Python中使用数组以更方便的方式编写长switch语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25096074/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com