RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 605474
Accepted
D.Ryksd
D.Ryksd
Asked:2020-12-20 02:40:27 +0000 UTC2020-12-20 02:40:27 +0000 UTC 2020-12-20 02:40:27 +0000 UTC

如何在字符串中连续查找三个单词?

  • 772

给定一个包含由空格分隔的单词和数字的字符串。需要在这一行中找到连续的三个单词。

def m (words) :
    a = 0
    for w in words.split() :
        pass
        while w.isalpha() is True :
            a += 1
            if a == 3 :
                return True
            else :
                return False    # вот на этом я застрял.
python
  • 3 3 个回答
  • 10 Views

3 个回答

  • Voted
  1. Best Answer
    Alexcei Shmakov
    2020-12-20T03:03:23Z2020-12-20T03:03:23Z

    这是一个可以满足您需要的功能。

    def m (words) :
        count = 0
        for w in words.split() :
            if w.isalpha() :
                count += 1
                if count == 3 :
                   return True
            else :
                count = 0
    
        return False    # вот на этом я застрял.
    

    该函数在循环中逐字运行。如果单词由字母组成(isalpha() 函数对此进行检查),则它会累加计数器(我们递增变量),否则会将其重置为零。如果计数器从三个单词开始累积,那么我们在该行中找到了 3 个连续的单词。

    • 6
  2. user194374
    2020-12-20T03:04:55Z2020-12-20T03:04:55Z

    该问题可以解决,例如,如下:

    def three_words(s):
        t = s.split()
        start = end = 0
        while end < len(t):
            if t[end].isalpha():
                if end - start >= 2:
                    return t[start:end + 1]
                end += 1
            else:
                start = end = end + 1
    

    该方法将返回连续遇到的前三个单词的列表,或者None如果没有这样的单词组。

    • 4
  3. jfs
    2020-12-20T10:12:29Z2020-12-20T10:12:29Z

    要在字符串中找到三个连续的单词并输出它们:

    words = text.split()
    for triple in zip(words, words[1:], words[2:]):
        if all(s.isalpha() for s in triple):
            print(*triple)
            break
    else: 
        print("not found")
    

    对于 Python 程序员来说,这是直接的代码,但它进行了不必要的复制和比较。

    这是类似于使用@Alexcei Shmakovcount的 答案的解决方案的代码 -此选项打印单词 triple 本身,而不仅仅是它是否在行中,作为解决方案:count

    triple = []
    for s in text.split():
        if s.isalpha():
            triple.append(s)
            if len(triple) == 3:
                print(*triple)
                break
        else:
            del triple[:] # empty
    else:
        print("not found")
    

    为了不创建一个可能很大的空格分隔字符串列表,可以使用正则表达式:

    import re
    
    m = re.search(r'\s+'.join([r'[^\d\s]+']*3), text)
    print(m.group() if m else "not found")
    

    此选项查找不是数字​​、空格的字符(适合设置问题中的问题),因为该re模块不支持模拟str.isalpha。regex模块支持\p{Letter}.

    测量可以显示性能与实际输入是否存在差异。

    • 3

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    如何停止编写糟糕的代码?

    • 3 个回答
  • Marko Smith

    onCreateView 方法重构

    • 1 个回答
  • Marko Smith

    通用还是非通用

    • 2 个回答
  • Marko Smith

    如何访问 jQuery 中的列

    • 1 个回答
  • Marko Smith

    *.tga 文件的组重命名(3620 个)

    • 1 个回答
  • Marko Smith

    内存分配列表C#

    • 1 个回答
  • Marko Smith

    常规赛适度贪婪

    • 1 个回答
  • Marko Smith

    如何制作自己的自动完成/自动更正?

    • 1 个回答
  • Marko Smith

    选择斐波那契数列

    • 2 个回答
  • Marko Smith

    所有 API 版本中的通用权限代码

    • 2 个回答
  • Martin Hope
    jfs *(星号)和 ** 双星号在 Python 中是什么意思? 2020-11-23 05:07:40 +0000 UTC
  • Martin Hope
    hwak 哪个孩子调用了父母的静态方法?还是不可能完成的任务? 2020-11-18 16:30:55 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    user207618 Codegolf——组合选择算法的实现 2020-10-23 18:46:29 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    Arch ArrayList 与 LinkedList 的区别? 2020-09-20 02:42:49 +0000 UTC
  • Martin Hope
    iluxa1810 哪个更正确使用:if () 或 try-catch? 2020-08-23 18:56:13 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5