【问题标题】:How to split string and map each character into dictionary [duplicate]如何拆分字符串并将每个字符映射到字典中[重复]
【发布时间】:2016-10-22 22:21:36
【问题描述】:

假设我有一个像 'value=sahi' 这样的字符串,我想要像 {1:s,2:a,3:h,4:i} 这样的字符串 有没有这样的功能。

【问题讨论】:

  • _, word = my_string.split('='); my_dict = {i: c for i, c in enumerate(word, 1)}.
  • 很遗憾,由于重复的问题是在询问数组,而这是一个字典 - 这是完全不同的。

标签: python dictionary


【解决方案1】:

我不知道具体的功能,但您可以使用 dict 理解:

s = "value=sahi"

d = {k+1: v for k, v in enumerate(s.split("=")[1])}

>>> {1: 's', 2: 'a', 3: 'h', 4: 'i'}

【讨论】:

  • enumerate 可以采用可选的起始索引,因此您不需要k+1
【解决方案2】:

你可以这样做:

value = "value=sahi"
value = value.replace("value=", "")

my_dict = {}
counter = 1

for c in value:
    my_dict[counter] = c
    counter += 1

for k, v in my_dict.iteritems():
    print k, v

【讨论】:

  • 这很不合Python。
【解决方案3】:

第 1 步:在'=' 上拆分给定的字符串。这将您不关心的部分和您关心的部分分开。在 Python 中,我们通常使用_ 来表示“不关心”。

_, word = given_string.split('=')

第 2 步:创建一个字典,将 1 索引位置映射到字符串中相应的 0 基索引字符。在 Python 中,enumerate 创建了一个可迭代的元组,它使用 0 索引位置来执行此操作。您可以提供一个可选的起始索引。在这种情况下,我们想从一个开始。

my_dict = {i: c for i, c in enumerate(word, 1)}

你可以清楚地在一行中做到这一点,但我认为最好是明确的,尤其是当理解已经很神奇的时候。 :)

【讨论】:

    猜你喜欢
    • 2019-08-29
    • 2017-09-22
    • 2020-01-19
    • 2016-07-23
    • 1970-01-01
    • 1970-01-01
    • 2011-01-18
    • 1970-01-01
    • 2021-08-06
    相关资源
    最近更新 更多