正则表达式使用

正则表达式符号含义

python 复制代码
\s 匹配任何空白字符,包括空格、制表符(\t)、换行符(\n)、回车符(\r)、垂直制表符(\v)和换页符(\f)。
\S 是 \s 的否定形式,匹配任何非空白字符。
\d 匹配任何数字字符,等价于 [0-9]。
.  表示任意字符
*  表示0个或多个字符
+  表示1个或多个字符

文本提取 示例代码

python 复制代码
import re
import sys

from utils.ocr_images_pdf import cno_ocr


# 发文日期
def extract_date(text):
    date_pattern = r'\d{4}年\d{1,2}月\d{1,2}日'
    match = re.search(date_pattern, text)   #re.search 或 re.match 方法时,match 对象包含了匹配的结果。如果你没有使用任何捕获组(即圆括号 ()),那么 match.group(0) 就是整个匹配的字符串。
    return match.group(0) if match else None


# 部门级别
def extract_department_level(text):
    level_pattern = r'市民政局.*?为(.+?)。'
    match = re.search(level_pattern, text)
    return match.group(1) if match else None


# 部门职责
def extract_duties(text):
    # 提取主要职责部分
    ''''''
    '''
    \s 匹配任何空白字符,包括空格、制表符(\t)、换行符(\n)、回车符(\r)、垂直制表符(\v)和换页符(\f)。
    \S 是 \s 的否定形式,匹配任何非空白字符。
    \d 匹配任何数字字符,等价于 [0-9]。
    .  表示任意字符
    *  表示0个或多个字符
    +  表示1个或多个字符
    '''
    duties_pattern = r'主要职责是:([\s\S]*?)第四条'
    match = re.search(duties_pattern, text)
    if match:
        duties_text = match.group(1).strip()

        # 统一文本中的括号类型
        # 将所有中英文括号替换为中文括号
        duties_text = duties_text.replace('(', '(').replace(')', ')')

        # print("Duties Text:\n", duties_text)  # 调试用,查看提取的职责文本

        # 定义可能的职责项标记
        delimiters = [
            '(一)', '(二)', '(三)', '(四)', '(五)',
            '(六)', '(七)', '(八)', '(九)', '(十)',
            '(十一)', '(十二)', '(十三)', '(十四)',
            '(十五)', '(十六)'
        ]

        duties_list = []
        start_idx = 0

        for delimiter in delimiters:
            # 查找下一个职责项的起始位置
            next_idx = duties_text.find(delimiter, start_idx)
            if next_idx == -1:
                break
            # 提取当前职责项的内容
            duty_content = duties_text[start_idx:next_idx].strip()
            if duty_content:
                duties_list.append(duty_content)
            # 更新开始位置
            start_idx = next_idx

        # 处理最后一个职责项
        last_duty_content = duties_text[start_idx:].strip()
        if last_duty_content:
            duties_list.append(last_duty_content)

        # 去除可能的多余空白字符
        formatted_duties = [duty.strip() for duty in duties_list if duty.strip()]

        # print("Duties List:\n", formatted_duties)
        return formatted_duties

    return []


# 内设机构职责
def extract_institutions(text):
    # 提取内设机构部分
    institutions_pattern = r'第四条市民政局设下列内设机构:([\s\S]*?)第五条'
    match = re.search(institutions_pattern, text)
    if match:
        institutions_text = match.group(1).strip()

        # 统一文本中的括号类型
        # 将所有中英文括号替换为中文括号
        institutions_text = institutions_text.replace('(', '(').replace(')', ')')

        # 定义可能的机构项标记
        delimiters = [
            '(一)', '(二)', '(三)', '(四)', '(五)',
            '(六)', '(七)', '(八)', '(九)', '(十)',
            '(十一)', '(十二)', '(十三)', '(十四)',
            '(十五)', '(十六)'
        ]

        institutions_dict = {}

        start_idx = 0
        for delimiter in delimiters:
            # 查找下一个机构项的起始位置
            next_idx = institutions_text.find(delimiter, start_idx)
            if next_idx == -1:
                break
            # 提取当前机构项的内容
            institution_content = institutions_text[start_idx:next_idx].strip()     # 在Python中,.strip() 是一个字符串方法,用于删除字符串两端的空白字符(包括空格、制表符、换行符等)。如果需要,也可以指定要删除的字符。
            if institution_content:
                # 分割机构名称和职责描述
                parts = institution_content.split('。', 1)
                if len(parts) == 2:
                    name, desc = parts
                    institutions_dict[name.strip()] = desc.strip()
                else:
                    name = parts[0].strip()
                    institutions_dict[name] = ''
            # 更新开始位置
            start_idx = next_idx + len(delimiter)

        # 处理最后一个机构项
        last_institution_content = institutions_text[start_idx:].strip()
        if last_institution_content:
            # 分割机构名称和职责描述
            parts = last_institution_content.split('。', 1)
            if len(parts) == 2:
                name, desc = parts
                institutions_dict[name.strip()] = desc.strip()
            else:
                name = parts[0].strip()
                institutions_dict[name] = ''

        # 去除可能的多余空白字符
        formatted_institutions = {k: v.strip() for k, v in institutions_dict.items() if k.strip()}

        return formatted_institutions

    return {}



class db_sql:
    """
    SQL语句
    'INSERT INTO "compare_department_duty_summary"(department_name,department_duty,act_id,\
    instance_id,summary_text,score,type, create_time, id) VALUES (%s,%s,%s,%s,%s,%s,%s,%s,%s)'
    """
    department_duty_insert_sql = 'INSERT INTO "department_duty"(department_name,department_duty) VALUES (%s,%s)'


def extract_department_duty():
    # 1 从PDF中提取文字内容
    filePath = ''
    save_dir = '../data/tmp_check_data/tem_test/'
    text = cno_ocr(filePath, save_dir)

    # 2 从文本内容中提取部门及其职责
    # text = ('')
    # 调用函数
    # 提取日期
    date = extract_date(text)

    # 提取部门级别
    department_level = extract_department_level(text)

    # 提前部门职责
    duties = extract_duties(text)

    # 提取内设机构职责
    institutions = extract_institutions(text)

    # 提取编制信息
    compilation = extract_compilation(text)



if "__main__" == __name__:
    extract_department_duty()
相关推荐
狐凄3 分钟前
Python实例题:Python计算概率论
开发语言·python·概率论
Y3174296 分钟前
python Day46 学习(日志Day15复习)
python·学习·机器学习
这里有鱼汤7 分钟前
一文读懂量化交易中最常用的5种均线,附源码,建议收藏
后端·python
学不会就看26 分钟前
selenium学习实战【Python爬虫】
python·学习·selenium
q5673152328 分钟前
分布式增量爬虫实现方案
开发语言·分布式·爬虫·python
勤奋的知更鸟34 分钟前
LLaMA-Factory和python版本的兼容性问题解决
开发语言·python·llama-factory
CIb0la36 分钟前
Ai自动补全编程工具:llama vscode
运维·开发语言·学习·测试工具·程序人生
1candobetter1 小时前
JAVA后端开发——多租户
java·开发语言
Takina~1 小时前
python打卡day48
pytorch·python·深度学习
freyazzr1 小时前
C++八股 | Day3 | 智能指针 / 内存管理 / 内存分区 / 内存对齐
开发语言·c++