纯爱战士Dylan1 发表于 2023-3-15 11:27:49

虚心求教!这个代码错在哪里?该如何改进呢?

虚心请教~


def process_string(s):

    words = s.split()

    result = []

    for x in words:

      if x % 2 == 0:

            result.append(x.lower())

      else:
            result.append(x.upper())   

               
    return result
   
print(process_string("This is my test String"))

isdkz 发表于 2023-3-15 11:39:28

你好!你在这段代码中想实现的功能是将字符串中的单词按照它们在句子中的位置进行大小写转换,

如果是偶数位置(从0开始计数)则转换为小写,否则转换为大写。

但是,代码里的问题是在if x % 2 == 0这一行,因为这里是对字符串进行求余数操作,这是不正确的。

我们需要对单词的索引进行判断,而非单词本身。你可以使用enumerate()函数来解决这个问题。

这里是修正后的代码:

def process_string(s):
    words = s.split()
    result = []

    for i, x in enumerate(words):
      if i % 2 == 0:
            result.append(x.lower())
      else:
            result.append(x.upper())

    return ' '.join(result)

print(process_string("This is my test String"))

运行这段代码,输出结果应该是:"this IS my TEST string"。

请注意,我还添加了' '.join(result),将处理后的单词列表重新组合成字符串。

纯爱战士Dylan1 发表于 2023-3-15 17:41:10

isdkz 发表于 2023-3-15 11:39
你好!你在这段代码中想实现的功能是将字符串中的单词按照它们在句子中的位置进行大小写转换,

如果是偶 ...

非常感谢!这很有用!

纯爱战士Dylan1 发表于 2023-3-15 17:43:32

isdkz 发表于 2023-3-15 11:39
你好!你在这段代码中想实现的功能是将字符串中的单词按照它们在句子中的位置进行大小写转换,

如果是偶 ...

还想请教一下如果不想使用 enumerate 函数,是否还有别的解决办法呢?

isdkz 发表于 2023-3-15 17:56:28

纯爱战士Dylan1 发表于 2023-3-15 17:43
还想请教一下如果不想使用 enumerate 函数,是否还有别的解决办法呢?

可以使用 for i in range(len(words))

不过更推荐使用 enumerate

纯爱战士Dylan1 发表于 2023-3-16 08:21:35

isdkz 发表于 2023-3-15 17:56
可以使用 for i in range(len(words))

不过更推荐使用 enumerate

好的谢谢~
页: [1]
查看完整版本: 虚心求教!这个代码错在哪里?该如何改进呢?