鱼C论坛

 找回密码
 立即注册
查看: 4669|回复: 5

[已解决]selenium page_source获得的数据跟F12查看框架里面的不一样!!

[复制链接]
发表于 2020-7-24 09:25:03 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x

我查看源码框架里面是这样的字典形式:

但是我用selenium获得的page_source确是这样的,多了一些html标签:



最佳答案
2020-7-24 15:33:37
可以用 selenium 模块的 switch_frame 切换框架便可以得到你想要的源代码。
请看示例:
  1. # 此脚本需要配合谷歌浏览器与谷歌驱动
  2. # 作者:那宏岩


  3. import urllib.request
  4. import re
  5. from selenium import webdriver
  6. from selenium.webdriver import ChromeOptions
  7. def search(music=None,singer=None):
  8.     if not music and not singer:
  9.         raise ValueError('参数错误!!')
  10.    
  11.     if not music:
  12.         name = singer
  13.     else:
  14.         name = music
  15.    
  16.       # 创建参数设置对象.
  17.     CLOUD_CHROME_OPTION = ChromeOptions()
  18.     CLOUD_CHROME_OPTION.binary_location = '.\\plug-in\\Google\\Chrome\\Application\\chrome.exe'
  19. #    chrome_opt.add_argument('--headless')   # 无界面化.
  20. #    chrome_opt.add_argument('--disable-gpu')    # 配合上面的无界面化.

  21.     driver = webdriver.Chrome(options = CLOUD_CHROME_OPTION,executable_path=r'chromedriver.exe')
  22.     driver.get('https://music.163.com/#/search/m/?s=' + name)
  23.     driver.switch_to.frame('g_iframe')
  24.     music_list = re.findall(r'<a href="/song\?id=(\d*)"><b title="(.*?)">',driver.page_source)
  25.     singer_list = re.findall(r'<a href="/artist\?id=\d*">(.*?)</a>',driver.page_source)
  26. #     driver.quit()
  27.     music_num = len(music_list)
  28.     download_list = list()
  29.     if singer:
  30.         for i in range(music_num):
  31.             if singer in singer_list[i]:
  32.                 download_list.append(music_list[i]+(singer_list[i],))
  33.     else:
  34.         for i in range(music_num):
  35.             download_list.append(music_list[i]+(singer_list[i],))
  36.             
  37.     print(download_list)
  38.         
  39.     down_load_sign = input(r'开始下载吗?[Y\N]:')
  40.     if down_load_sign == 'Y':
  41.         for each_music in download_list:
  42.             print(f'{each_music[1]}-{each_music[2]}.mp3正在下载!')
  43.             urllib.request.urlretrieve(f'http://music.163.com/song/media/outer/url?id={each_music[0]}.mp3',f'C:\\CLOUD Artification Intelligence\\clouddata\\Sound\\{each_music[1]}-{each_music[2]}.mp3')
  44.             print(f'{each_music[1]}-{each_music[2]}.mp3下载完成!')
  45.         
  46.             

  47. if __name__ == '__main__':
  48.     while True:
  49. #         music_name = input('请输入歌曲名:')
  50. #         singer_name = input('请输入歌手名:')
  51.         music_name = '大鱼'
  52.         singer_name = ''
  53.         search(music_name,singer_name)
复制代码

源码框架

源码框架

page-source获得的数据

page-source获得的数据
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-7-24 09:55:00 | 显示全部楼层


审核元素可能是其他文件加载的,所以不一样
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-7-24 14:13:15 | 显示全部楼层
Twilight6 发表于 2020-7-24 09:55
审核元素可能是其他文件加载的,所以不一样

那有没有什么办法可以让我获得的界面源码是f12查看到的那种字典呢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-24 14:45:20 | 显示全部楼层

回帖奖励 +1 鱼币

这个问题我还真的没想过
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-24 15:31:03 | 显示全部楼层
可以用 driver.switch_frame()函数切换框架就可以得到你想要的源代码了。
请看示例,这是我以前写的网易云音乐爬虫:
  1. # 此脚本需要配合谷歌浏览器与谷歌驱动
  2. # 作者:那宏岩


  3. import urllib.request
  4. import re
  5. from selenium import webdriver
  6. from selenium.webdriver import ChromeOptions
  7. def search(music=None,singer=None):
  8.     if not music and not singer:
  9.         raise ValueError('参数错误!!')
  10.    
  11.     if not music:
  12.         name = singer
  13.     else:
  14.         name = music
  15.    
  16.       # 创建参数设置对象.
  17.     CLOUD_CHROME_OPTION = ChromeOptions()
  18.     CLOUD_CHROME_OPTION.binary_location = '.\\plug-in\\Google\\Chrome\\Application\\chrome.exe'
  19. #    chrome_opt.add_argument('--headless')   # 无界面化.
  20. #    chrome_opt.add_argument('--disable-gpu')    # 配合上面的无界面化.

  21.     driver = webdriver.Chrome(options = CLOUD_CHROME_OPTION,executable_path=r'chromedriver.exe')
  22.     driver.get('https://music.163.com/#/search/m/?s=' + name)
  23.     driver.switch_to.frame('g_iframe')
  24.     music_list = re.findall(r'<a href="/song\?id=(\d*)"><b title="(.*?)">',driver.page_source)
  25.     singer_list = re.findall(r'<a href="/artist\?id=\d*">(.*?)</a>',driver.page_source)
  26. #     driver.quit()
  27.     music_num = len(music_list)
  28.     download_list = list()
  29.     if singer:
  30.         for i in range(music_num):
  31.             if singer in singer_list[i]:
  32.                 download_list.append(music_list[i]+(singer_list[i],))
  33.     else:
  34.         for i in range(music_num):
  35.             download_list.append(music_list[i]+(singer_list[i],))
  36.             
  37.     print(download_list)
  38.         
  39.     down_load_sign = input(r'开始下载吗?[Y\N]:')
  40.     if down_load_sign == 'Y':
  41.         for each_music in download_list:
  42.             print(f'{each_music[1]}-{each_music[2]}.mp3正在下载!')
  43.             urllib.request.urlretrieve(f'http://music.163.com/song/media/outer/url?id={each_music[0]}.mp3',f'C:\\CLOUD Artification Intelligence\\clouddata\\Sound\\{each_music[1]}-{each_music[2]}.mp3')
  44.             print(f'{each_music[1]}-{each_music[2]}.mp3下载完成!')
  45.         
  46.             

  47. if __name__ == '__main__':
  48.     while True:
  49. #         music_name = input('请输入歌曲名:')
  50. #         singer_name = input('请输入歌手名:')
  51.         music_name = '大鱼'
  52.         singer_name = ''
  53.         search(music_name,singer_name)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2020-7-24 15:33:37 | 显示全部楼层    本楼为最佳答案   
可以用 selenium 模块的 switch_frame 切换框架便可以得到你想要的源代码。
请看示例:
  1. # 此脚本需要配合谷歌浏览器与谷歌驱动
  2. # 作者:那宏岩


  3. import urllib.request
  4. import re
  5. from selenium import webdriver
  6. from selenium.webdriver import ChromeOptions
  7. def search(music=None,singer=None):
  8.     if not music and not singer:
  9.         raise ValueError('参数错误!!')
  10.    
  11.     if not music:
  12.         name = singer
  13.     else:
  14.         name = music
  15.    
  16.       # 创建参数设置对象.
  17.     CLOUD_CHROME_OPTION = ChromeOptions()
  18.     CLOUD_CHROME_OPTION.binary_location = '.\\plug-in\\Google\\Chrome\\Application\\chrome.exe'
  19. #    chrome_opt.add_argument('--headless')   # 无界面化.
  20. #    chrome_opt.add_argument('--disable-gpu')    # 配合上面的无界面化.

  21.     driver = webdriver.Chrome(options = CLOUD_CHROME_OPTION,executable_path=r'chromedriver.exe')
  22.     driver.get('https://music.163.com/#/search/m/?s=' + name)
  23.     driver.switch_to.frame('g_iframe')
  24.     music_list = re.findall(r'<a href="/song\?id=(\d*)"><b title="(.*?)">',driver.page_source)
  25.     singer_list = re.findall(r'<a href="/artist\?id=\d*">(.*?)</a>',driver.page_source)
  26. #     driver.quit()
  27.     music_num = len(music_list)
  28.     download_list = list()
  29.     if singer:
  30.         for i in range(music_num):
  31.             if singer in singer_list[i]:
  32.                 download_list.append(music_list[i]+(singer_list[i],))
  33.     else:
  34.         for i in range(music_num):
  35.             download_list.append(music_list[i]+(singer_list[i],))
  36.             
  37.     print(download_list)
  38.         
  39.     down_load_sign = input(r'开始下载吗?[Y\N]:')
  40.     if down_load_sign == 'Y':
  41.         for each_music in download_list:
  42.             print(f'{each_music[1]}-{each_music[2]}.mp3正在下载!')
  43.             urllib.request.urlretrieve(f'http://music.163.com/song/media/outer/url?id={each_music[0]}.mp3',f'C:\\CLOUD Artification Intelligence\\clouddata\\Sound\\{each_music[1]}-{each_music[2]}.mp3')
  44.             print(f'{each_music[1]}-{each_music[2]}.mp3下载完成!')
  45.         
  46.             

  47. if __name__ == '__main__':
  48.     while True:
  49. #         music_name = input('请输入歌曲名:')
  50. #         singer_name = input('请输入歌手名:')
  51.         music_name = '大鱼'
  52.         singer_name = ''
  53.         search(music_name,singer_name)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-24 04:38

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表