文章目录
前言
为了巩固所学的知识,作者尝试着开始发布一些学习笔记类的博客,方便日后回顾。当然,如果能帮到一些萌新进行新技术的学习那也是极好的。作者菜菜一枚,文章中如果有记录错误,欢迎读者朋友们批评指正。
(博客的参考源码可以在我主页的资源里找到,如果在学习的过程中有什么疑问欢迎大家在评论区向我提出)
发现宝藏
前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。【宝藏入口】。
一、需求分析
1. 这是一个标准的章节目录,我们需要保留目录的前两级标题,也就是包含章和节字的标题
2. 需要在二级标题所在行最前面空4个格子,一级标题不用
3. 需要在章和节字的后面加上一个空格
4. 需要在页码前面加上=>符号
5. 示例效果如下:
二、操作步骤详解(标准章节)
1. 提取文章目录
1. 图片识别文字提取文章目录
http://183.62.34.62:8004/docs#/defaul/text_detection_text_system_analysis_menus__post
2. 使用方法
3. 识别示例
2. 更改保存目录.txt
你可以使用Python中的open函数来打开文件,read方法读取文件内容,然后对内容进行修改,最后使用write方法将修改后的内容写回文件。以下是一个简单的例子:
import os
# 获取桌面路径
desktop_path = os.path.join(os.path.expanduser("~"), "Desktop")
# 目标文件路径
file_path = os.path.join(desktop_path, "目录.txt")
# 打开文件并读取内容
with open(file_path, 'r', encoding='utf-8') as file:
content = file.read()
# 修改内容(这里只是一个简单的例子)
modified_content = content.replace('章', '章666')
# 将修改后的内容写回文件
with open(file_path, 'w', encoding='utf-8') as file:
file.write(modified_content)
请确保你有足够的权限读取和写入文件。此外,这只是一个简单的例子,如果需要进行更复杂的操作,可以使用正则表达式或其他处理方式来实现。
3. 二级标题前面加4个空格
# 去除空格
line = line.replace(" ", "")
if '节' in line:
# 二级标题添加4个空格
line = ' ' * 4 + line
lstrip(' ') 是 Python 字符串方法,用于删除字符串开头(左侧)的指定字符。在这里,' ' 表示空格字符。
4. 在章字和节字后面添加一个空格
# 使用正则表达式在'章'或'节'后面添加一个空格
line = re.sub(r'(章|节)(?![ ])', r'\1 ', line)
5. 在页码前面加上=>符号
# 匹配并去除最外层的英文括号
pattern_en = r'\(([\d\s]+)\)'
line = re.sub(pattern_en, r'\1', line)
# 匹配并去除最外层的中文括号及其内部内容(包括空格)
pattern = r'(([^)]+))'
line = re.sub(pattern, r'\1', line)
line = line.replace(" ", "")
# 确保每行只有一个 =>
if '=>' not in line:
# 在每行数字前加上 =>
line = re.sub(r'(\d+)', r'=>\1', line)
6. 代码完全体
# 获取桌面路径
import os
import re
desktop_path = os.path.join(os.path.expanduser("~"), "Desktop")
# 目标文件路径
file_path = os.path.join(desktop_path, "目录.txt")
# 打开文件并读取内容
with open(file_path, 'r', encoding='utf-8') as file:
lines = file.readlines()
modified_lines = []
for line in lines:
# 去除空格
line = line.replace(" ", "")
# 匹配并去除最外层的英文括号
pattern_en = r'\(([\d\s]+)\)'
line = re.sub(pattern_en, r'\1', line)
# 匹配并去除最外层的中文括号及其内部内容(包括除数字和空格以外的字符)
pattern = r'(([^)]+))'
line = re.sub(pattern, r'\1', line)
# 确保每行只有一个 =>
if '=>' not in line:
# 在每行数字前加上 =>
line = re.sub(r'(\d+)', r'=>\1', line)
# 使用正则表达式在'章'或'节'后面添加一个空格
line = re.sub(r'(章|节)(?![ ])', r'\1 ', line)
if '节' in line:
# 二级标题添加4个空格
line = ' ' * 4 + line
modified_lines.append(line)
# 将修改后的内容写回文件
with open(file_path, 'w', encoding='utf-8') as file:
file.writelines(modified_lines)
# 读取文件内容
with open(file_path, 'r', encoding='utf-8') as file:
content = file.read()
print(content)
三、进阶一(有章无节+小数二级标题)
1. 二级标题前面加4个空格
如果章字不在行内,则初步认定他为二级标题
# 去除空格
line = line.replace(" ", "")
if '章' not in line:
# 二级标题添加4个空格
line = ' ' * 4 + line
2. 在标题里面添加一个空格
# 使用正则表达式在'章'或'节'后面添加一个空格,仅在后面没有空格的情况下
line = re.sub(r'(章|节)(?![ ])', r'\1 ', line)
# 在小数点后添加空格
line = re.sub(r'(\.\d)', r'\1 ', line)
3. 在页码前面加上=>符号
# 匹配并去除最外层的英文括号
pattern_en = r'\(([\d\s]+)\)'
line = re.sub(pattern_en, r'\1', line)
# 匹配并去除最外层的中文括号及其内部内容(包括除数字和空格以外的字符)
pattern = r'(([^)]+))'
line = re.sub(pattern, r'\1', line)
# 确保每行只有一个 =>
if '=>' not in line:
# 在页码数字前添加 =>(只在行尾)
line = re.sub(r'(\d+)$', r'=>\1', line)
4. 去除=>符号和汉字之间的冗余符号
# 去除中文汉字和'=>整体符号左边的冗余符号
pattern = r'([\u4e00-\u9fff]+)[^\w\s]+=>'
line = re.sub(pattern, r'\1=>', line)
5. 删除空行
# 去除空格
line = line.replace(" ", "")
if len(line) == 1:
continue
6. 一般参考文献后面的都是一级标题
# 定义一个判断标准,用于区分参考文献后面的行数
under_cankao = False
for line in lines:
# 参考文献后面的都是一级标题
if line.startswith(" 参考文献"):
under_cankao = True
if under_cankao == True:
line = line.lstrip()
modified_lines.append(line)
7. 代码完全体
# 获取桌面路径
import os
import re
desktop_path = os.path.join(os.path.expanduser("~"), "Desktop")
# 目标文件路径
file_path = os.path.join(desktop_path, "目录.txt")
# 打开文件并读取内容
with open(file_path, 'r', encoding='utf-8') as file:
lines = file.readlines()
modified_lines = []
for line in lines:
# 去除空格
line = line.replace(" ", "")
# 使用正则表达式在'章'或'节'后面添加一个空格,仅在后面没有空格的情况下
line = re.sub(r'(章|节)(?![ ])', r'\1 ', line)
# 在小数点后添加空格
line = re.sub(r'(\.\d)', r'\1 ', line)
if '章' not in line:
# 二级标题添加4个空格
line = ' ' * 4 + line
# 匹配并去除最外层的英文括号
pattern_en = r'\(([\d\s]+)\)'
line = re.sub(pattern_en, r'\1', line)
# 匹配并去除最外层的中文括号及其内部内容(包括除数字和空格以外的字符)
pattern = r'(([^)]+))'
line = re.sub(pattern, r'\1', line)
# 确保每行只有一个 =>
if '=>' not in line:
# 在页码数字前添加 =>(只在行尾)
line = re.sub(r'(\d+)$', r'=>\1', line)
# 去除中文汉字和'=>整体符号左边的冗余符号
pattern = r'([\u4e00-\u9fff]+)[^\w\s]+=>'
line = re.sub(pattern, r'\1=>', line)
modified_lines.append(line)
# 将修改后的内容写回文件
with open(file_path, 'w', encoding='utf-8') as file:
file.writelines(modified_lines)
# 读取文件内容
with open(file_path, 'r', encoding='utf-8') as file:
content = file.read()
print(content)
8. 进阶说明
1. 兼容标准章节版本
2. 章和章之间识别为第二级目录
3. 只在标题末尾页码数字添加=>符号
4. 去除箭头和汉字之间识别出来的冗余符号
5. 去除空行
6. 参考文献后面的作为一级标题
三、进阶二 (无章无节+页码前置)
1. 页码后置
带小数点的代表的是二级标题,无需后置;不带小数点的一般是页码需要后置
for line in lines:
# 去除空格
line = line.replace(" ", "")
# 使用正则表达式匹配开头的数字
match = re.match(r'^(\d+)', line)
# 如果存在小数点则是二级标题
before_str = line[:3]
if '.' in before_str:
match = False
if match:
# 如果匹配到整数数字,将数字移到行尾
modified_line = line.lstrip(match.group(0)).replace('\n', '') + match.group(0)
line = modified_line + '\n'
2. 对一二级标题判定的修改
上面我们是根据章字所在行去判断一级标题,但根据页码相同去判断才是通用的逻辑,但是也有存在含章字的一级标题跟二级标题页码不一致的情况
# 兼容无章无节
if i + 1 <= len(lines) - 1:
# 使用正则表达式匹配每一行最前面和最后面的数字
current_page_number = re.findall(r'^\d+|\d+$', lines[i], re.MULTILINE)
next_page_number = re.findall(r'^\d+|\d+$', lines[i+1], re.MULTILINE)
if current_page_number and next_page_number and current_page_number == next_page_number:
# 页码一样,删除当前行的空格
lines[i] = lines[i].lstrip()
else:
different_num = different_num + 1
# 页码和下一行不一样的都是二级标题
lines[i] = lines[i]
# 兼容带章字的文本
if '章' in lines[i]:
lines[i] = lines[i].replace(' ', '')
3. 如果所有页码都不同则都看做一级标题
# 判断是否都是一级标题
different_num = 0
# 判断是否是章节格式
zhang_jie = False
...
# 页码和下一行不一样的都是二级标题
different_num = different_num + 1
...
if different_num == len(lines) - 1 and zhang_jie == False:
# 去除每一行的空格
modified_lines = [line.strip()+'\n' for line in modified_lines]
4. 代码完全体
# 获取桌面路径
import os
import re
desktop_path = os.path.join(os.path.expanduser("~"), "Desktop")
# 目标文件路径
file_path = os.path.join(desktop_path, "目录.txt")
# 打开文件并读取内容
with open(file_path, 'r', encoding='utf-8') as file:
lines = file.readlines()
modified_lines = []
# 判断是否位于参考文献之下
under_cankao = False
# 判断是否都是一级标题
different_num = 0
# 判断是否是章节格式
zhang_jie = False
for i in range(len(lines)):
# 去除空格
lines[i] = lines[i].replace(" ", "")
# 使用正则表达式匹配开头的数字
match = re.match(r'^(\d+)', lines[i])
before_str = lines[i][:3]
if '.' in before_str:
match = False
if match:
# 如果匹配到整数数字,将数字移到行尾
modified_line = lines[i].lstrip(match.group(0)).replace('\n', '') + match.group(0)
lines[i] = modified_line + '\n'
if len(lines[i]) == 1:
continue
# 统一加4个空格
lines[i] = ' ' * 4 + lines[i]
# 使用正则表达式在'章'或'节'后面添加一个空格,仅在后面没有空格的情况下
lines[i] = re.sub(r'(章|节)(?![ ])', r'\1 ', lines[i])
# 在小数点后添加空格
lines[i] = re.sub(r'(\.\d)', r'\1 ', lines[i])
# 兼容无章无节
if i + 1 <= len(lines) - 1:
# 使用正则表达式匹配每一行最前面和最后面的数字
current_page_number = re.findall(r'^\d+|\d+$', lines[i], re.MULTILINE)
next_page_number = re.findall(r'^\d+|\d+$', lines[i+1], re.MULTILINE)
if current_page_number and next_page_number and current_page_number == next_page_number:
# 页码一样,删除当前行的空格
lines[i] = lines[i].lstrip()
else:
different_num = different_num + 1
# 页码和下一行不一样的都是二级标题
lines[i] = lines[i]
# 兼容带章字的文本
if '章' in lines[i]:
zhang_jie = True
lines[i] = lines[i].replace(' ', '')
# 匹配并去除最外层的英文括号
pattern_en = r'\(([\d\s]+)\)'
lines[i] = re.sub(pattern_en, r'\1', lines[i])
# 匹配并去除最外层的中文括号及其内部内容(包括除数字和空格以外的字符)
pattern = r'(([^)]+))'
lines[i] = re.sub(pattern, r'\1', lines[i])
# 确保每行只有一个 =>
if '=>' not in lines[i]:
# 在页码数字前添加 =>(只在行尾)
lines[i] = re.sub(r'(\d+)$', r'=>\1', lines[i])
# 去除中文汉字和'=>整体符号左边的冗余符号
pattern = r'([\u4e00-\u9fff]+)[^\w\s]+=>'
lines[i] = re.sub(pattern, r'\1=>', lines[i])
# 参考文献后面的都是一级标题
if '参考文献' in lines[i]:
under_cankao = True
if under_cankao == True:
lines[i] = lines[i].lstrip()
modified_lines.append(lines[i])
# 所有页码均不相同的时候都视为一级标题
if different_num == len(lines) - 1 and zhang_jie == False:
# 去除每一行的空格
modified_lines = [line.strip()+'\n' for line in modified_lines]
# 将修改后的内容写回文件
with open(file_path, 'w', encoding='utf-8') as file:
file.writelines(modified_lines)
# 读取文件内容
with open(file_path, 'r', encoding='utf-8') as file:
content = file.read()
print(content)
5. 进阶说明
1. 兼容标准章节和进阶一版本
2. 期刊的相同页码第一个识别为一级目录,也兼容了书本的一二级目录页码不相同的情况
3. 把页码提前并对小数点二级标题加以区分
4. 当所有页码都不相同的时候所有标题视为一级目录
拓展与补充
1. content = file.read() 与 lines = file.readlines() 读取文件的区别
在 Python 中,file.read() 和 file.readlines() 两者可以在同一个文件句柄中使用,但是要注意的是,file.read() 会读取整个文件内容为一个字符串,而 file.readlines() 会读取整个文件内容并将每一行作为一个字符串放入列表中
如果你使用了 file.read(),那么之后再使用 file.readlines() 将不会得到任何内容,因为文件指针已经在文件的末尾。如果需要再次读取文件,你可以使用 file.seek(0) 将文件指针重新定位到文件的开头
以下是一个演示的例子:
# 使用 file.read()
with open('example.txt', 'r', encoding='utf-8') as file:
content = file.read()
print(content)
# 使用 file.readlines(),注意在上面使用了 file.read() 之后,需要重新打开文件或者使用 file.seek(0)
with open('example.txt', 'r', encoding='utf-8') as file:
file.seek(0)
lines = file.readlines()
print(lines)
总的来说,两者是可以在同一个文件句柄中使用的,只是需要注意文件指针的位置。
总结
欢迎各位留言交流以及批评指正,如果文章对您有帮助或者觉得作者写的还不错可以点一下关注,点赞,收藏支持一下。
(博客的参考源码可以在我主页的资源里找到,如果在学习的过程中有什么疑问欢迎大家在评论区向我提出)