python实战(爬取一个小说网站,将爬取的文本转换为语音)

2024-06-22 19:04

本文主要是介绍python实战(爬取一个小说网站,将爬取的文本转换为语音),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.前言

  • 有声小说相信大家都不陌生了, 里面的音频基本都是一些声优录制的
  •  其实除了录制音频, 咱们可以利用百度免费的api接口使用python语言在线合成语音
  •  制作属于自己的有声小说, 一睹为快吧!!

2.爬取小说网站

爬取的网站http://www.xbiquge.la/10/10489/

代码示例:

# -*- coding: utf-8 -*-
# @File : 爬取文本内容.py
# @Time : 2024/6/20 15:35
# @Author : syq
# @Email : 1721169065@qq.com
# @Software: PyCharm
import requests  # 数据请求模块 ,第三方模块
import re  # 内置模块
def get_chapter(number):''':param number: 该参数是你要爬取的哪一章:return:'''# 1.确定数据的url链接地址url = 'http://www.xbiquge.la/10/10489/'# 2.发送请求response = requests.get(url=url)response.encoding = response.apparent_encoding   # 自动识别响应对象的编码html_data = response.text# print(html_data)# 3.解析数据(只解析小说,获取每一章节小说的链接)chapter_list_url = re.findall("<dd><a href='(.*?)' >.*?</a></dd>", html_data, re.S) #看自己要哪些数据print(chapter_list_url)# 爬取指定章节的小说chapter = chapter_list_url[number]print(chapter)# 构建小说的全部地址all_url = 'http://www.xbiquge.la' + chapterresponse_2 = requests.get(url=all_url)response_2.encoding = response_2.apparent_encoding  # 自动识别响应对象的编码html_data_2 = response_2.text#print(html_data_2)"""<div id="content">(.*?)<p>.*</p></div>"""# 解析小说文本数据result = re.findall('<div id="content">(.*?)<p>.*</p></div>', html_data_2, re.S)# print(result)# 4.保存数据with open('a.txt', mode='w', encoding='utf-8') as f:f.write(result[0].replace('&nbsp;', '').replace('<br />', ''))number = int(input('请输入你想要爬取的章节(输入数字):'))
get_chapter(number)

运行后,生成了a.txt文件

项目文件中有生成的文件,但是pycharm中没有,解决方法,如下图:

查看a.txt文件的内容

 

代码分析:

(1)代码的#1.2获取每个章节独有的链接名称 得到的是一个列表

正则表达式的写法,是根据如下图来的:

(2)代码的#3.获取小说的文本信息

正则表达式的写法,是根据如下图来的:

3.把爬取的小说文本转换为语音

调用百度AI的免费接口,参考如下链接(要从百度AI中获取3个参数值)

百度AI-语音合成(python代码练习-把文本转换为语音)-CSDN博客

代码:

# -*- coding: utf-8 -*-
# @File : 文本转语音.py
# @Time : 2024/6/21 9:26
# @Author : syq
# @Email : 1721169065@qq.com
# @Software: PyCharm
from aip import AipSpeech""" 你的 APPID AK SK """
APP_ID = '84493676'
API_KEY = '4dXEGpehJRDWYvvZI6ewNoL9'
SECRET_KEY = 'bbWB7DG2GHUuBLkU6XOMQbwL3TS4AUPf'
client = AipSpeech(APP_ID, API_KEY, SECRET_KEY)# 读取数据, 处理文本的长度
with open('a.txt', mode='r', encoding='utf-8') as f:# text = f.read()# print(text)flag = 0while True:flag += 1text = f.read(512)  # 每次去取512字节if not text:break# print(text)# print('*' * 100)result  = client.synthesis(text, 'zh', 1, {'vol': 5,# 'spd': 4,# 'pit': 9,# 'per': 1})# 识别正确返回语音二进制 错误则返回dict 参照下面错误码if not isinstance(result, dict):with open(f'video\\{flag}.mp3', 'wb') as file:if flag<=3: #因为a.txt的文字有点多,所以不让他全部生成print(f'正在生成第 {flag} 个语音...')file.write(result)else:breakelse:print(result)

注意:text = f.read(512)  # 每次去取512字节

这样写的原因:

运行结果:

如果运行完成后,video中没有看到生成的mp3文件,但是本地磁盘的项目目录有,就右键点一下Reload  from Disk

注:爬取小说内容.py模块可删除!!!

如有需要代码,可在资源中自行下载

这篇关于python实战(爬取一个小说网站,将爬取的文本转换为语音)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1085144

相关文章

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

Python安装时常见报错以及解决方案

《Python安装时常见报错以及解决方案》:本文主要介绍在安装Python、配置环境变量、使用pip以及运行Python脚本时常见的错误及其解决方案,文中介绍的非常详细,需要的朋友可以参考下... 目录一、安装 python 时常见报错及解决方案(一)安装包下载失败(二)权限不足二、配置环境变量时常见报错及