Python从网页中提取到了一段数据,怎么在这段数据中查找是否存在我想要的并返回一个结果?

比如具体代码如下:
print result
32:aaaaaa
33:bbbbbb
34:ccccccc
35:ddddddd
如果我想知道这些数据里面是否包含字符窜‘aaaaaa’,如果是则返回前面的数值。否的话则返回一个‘Not Match’之类的,该怎么写这一段代码?目前type(result)的结果是unicode,是否需要转化为字典?

阅读 3.8k
3 个回答
# -*- coding:utf-8 -*-

result = """32:aaaaaa
33:bbbbbb
34:ccccccc
35:ddddddd"""


def getNumber(str):
    for line in result.split('\n'):
        group = line.split(':')
        if str in group:
            return group[0]
    return False

if __name__ == '__main__':
    print(getNumber('aaaaaa'))
    print(getNumber('asdfe'))
32
False

@liguangsheng 的想法是對的, 可惜代碼有一點點問題

def getNumber(str):
    for line in result.split('\n'):
        group = line.split(':')
        if str in group:
            return group[0]
        return False # <------------------------ 問題出在這裡

這會導致第一行沒有找到 str 就失敗, 比如說可以試一下:

print(getNumber('bbbbbb'))

這應該找的到的, 但會回傳 False

我小改了一下:

def find(data, keyword):
    pairs = (line.strip().split(':') for line in result.split('\n'))
    for i, words in pairs:
        if keyword in words.split():
            return i
    return None # <--------- return should be here

if __name__=='__main__':

    result = """32:aaaaaa
    33:bbbbbb
    34:ccccccc
    35:ddddddd"""

    print(find(result, 'aaaaaa'))
    print(find(result, 'ccccccc'))
    print(find(result, 'abcdefg'))

結果:

32
34
None

我回答過的問題: Python-QA

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题