在指定文件夹中提取含有特定字符的所有文件并保存到指定路径

在实际操作中,往往需要将文件夹中的文件名含有某个特定字符的文件批量提取或是处理,本文采用python编程实现这一功能。代码仅供参考,直接上代码:

import os
import shutil
 
def select_files(dir, dir_out):
    s1 = 'A'
    r1 = 'B'
    sd = 'C'
    newDir = dir 
    if os.path.isfile(dir):
        if(dir[-4:] == '.png' and ((s1 in dir) or (r1 in dir))):#提取文件夹dir中包含A或是B的格式为png的所有图像
        # if (dir[-4:] == '.bmp' and ((r1 in dir))):#提取文件夹dir中包含B的格式为bmp的所有图像
        # if (dir[-4:] == '.jpg' and (sd in dir)):#提取文件夹dir中包含C的格式为jpg的所有图像
            filename = dir.split('\\')[-3]
            filename += dir.split('\\')[-1]
            shutil.copy(dir, os.path.join(dir_out, filename)) #将提取的文件保存到dir_out文件夹中

具体如何使用以上代码,可以在标注中更为直观的了解。

Python,你可以使用`os`, `re`, 和 `pdfplumber` 这些库来查找指定文件夹下的PDF文件包含特定关键字,并提取前后10个字符的信息。以下是一个基本示例: ```python import os import re from pdfplumber import PDF # 定义要搜索的关键字和要保存结果的路径 keyword = "your_keyword" output_folder = "./output" def extract_text_from_pdf(pdf_path): with PDF(pdf_path) as pdf: text = "" for page in pdf.pages: text += page.extract_text() return text def search_and_extract(pdf_text, keyword, n_chars=10): matches = [m.start() - n_chars for m in re.finditer(keyword, pdf_text)] return [(match, pdf_text[match : match + (n_chars * 2)]) for match in matches] # 遍历文件夹 for root, dirs, files in os.walk(".", topdown=True): if ".pdf" in files: file_path = os.path.join(root, files[0]) pdf_text = extract_text_from_pdf(file_path) if keyword in pdf_text: matched_results = search_and_extract(pdf_text, keyword) # 保存匹配到的结果 save_results(matched_results, output_folder) def save_results(results, folder): os.makedirs(folder, exist_ok=True) for index, match_info in enumerate(results): start, context = match_info with open(f"{folder}/result_{index}.txt", 'w') as f: f.write(f"Keyword found at position {start}, context: {context}") # 调用函数开始处理 search_and_extract(keyword=keyword, n_chars=10) ``` 这个脚本首先打开每个PDF,提取文本,然后搜索关键字并保存匹配到位置及其前后10个字符的内容。请注意,你需要安装`pdfplumber`库来解析PDF(可以使用pip install pdfplumber),并且此脚本仅返回了匹配的位置,如果需要更详细的上下文信息,你可能需要调整提取内容的方式。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

gz7seven

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值