TypeError: expected string or bytes-like..

 时间:2026-02-16 18:36:14

1、代码,如下所示:

import refrom crawling import downloadimport urllib.parsedef link_crawler(seed_url,link_regex):    """Crawl from the given seed URL following links matched b link_regex    """    crawl_queue = [seed_url]    while crawl_queue:        url = crawl_queue.pop()        html = download(url)        #filter for links matching our regular expressiong        for link in get_links(html):            if re.match(link_regex,link):                crawl_queue.append(link)def get_links(html):    """Return a list of links from html"""    # a regular expression to extract all links from the webpage    webpage_regex = re.compile('<a[^>]+href=["\'](.*?)["\']',        re.IGNORECASE)    #List of all links from the webpage    return webpage_regex.findall(html)link_crawler('http://example.webscraping.com','/(index|view)')

TypeError: expected string or bytes-like..

2、运行之后报错:

TypeError: expected string or bytes-like object

3、分析可得是:字符串相关问题

这里看一下findall:

re.findall(pattern, string[, flags]):

解释为:搜索string,以列表形式返回全部能匹配的子串。

TypeError: expected string or bytes-like..

TypeError: expected string or bytes-like..

4、所以我们要将 return webpage_regex.findall(html)中的html 改为str(html)

TypeError: expected string or bytes-like..

5、运行后,成功。

如果您觉得有帮助的话,帮我投个票吧。

TypeError: expected string or bytes-like..

  • Windows如何使用FFMPEG给MP4文件切片并生成m3u8
  • 集装箱如何装箱
  • ORCAD中调用封装元件的方法
  • sqlitestudio怎么编写sql语句
  • 东北一锅出怎么做?
  • 热门搜索
    怎么理财收益最大 笔记本小键盘怎么关 耐克怎么辨别真假 我的世界怎么酿造药水 头发少怎么扎好看 放风筝用英语怎么说 italian怎么读 邪气鞍座怎么获得 free怎么读 淡菜怎么吃