讯飞AI算法挑战大赛-校招简历信息完整性检测挑战赛-三等奖方案

本文主要是介绍讯飞AI算法挑战大赛-校招简历信息完整性检测挑战赛-三等奖方案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

本文公开了”讯飞AI算法挑战大赛-校招简历信息完整性检测挑战赛“赛道的技术方案,本次比赛主要采用pdf解析特征工程的方法,通过使用lightgbm的树模型10折交叉验证进行二分类的任务,最终取得三等奖的成绩。

一、赛题任务

简历智能化判断,需要大量的数据集作为支撑,同时简历的半结构化数据特点和多变的简历风格给简历智能化判断带来了挑战,本次大赛将提供脱敏的学生中文简历数据集(pdf或docx格式)作为训练样本,参赛选手需要基于提供的样本数据构建模型,预测简历是否符合简历投递基本要求。任务如下:

简历完整性检测。根据要求提取简历要素特征数据,并根据样本数据构建模型,预测简历是否符合简历投递基本要求,预测结果可分为两个类别:即完整(标签1)不完整(标签0)

二、数据和评价指标

数据:脱敏后的学生简历数据集(pdf或docx格式)。训练数据提供脱敏后的数据集,共800余份。测试集不可见,由真实简历数据组成,共100余份。训练集全部为pdf格式。

注:数据集分为正样本负样本,其中正样本为完整性简历数据集,符合简历投递基本要求;负样本为不完整简历数据集,不符合简历投递基本要求。

评价指标:F1 score

三、方案

3.1.方案概述

本次比赛主要采用pdf解析和特征工程的方法,通过使用lightgbm的树模型10折交叉验证进行二分类的任务。

3.2.pdf2text解析

本次比赛主要实验了以下几种解析工具,最终最高分选择了pymupdf

  • pdfplumber
  • PyPDF2
  • pymupdf

3.3.特征工程

主要文本特征如下:

  • 页数

  • pdf2text的文本长度

  • 按行切分后的平均长度

  • 按行切分后的最大长度

  • 按行切分后的长度标准差

  • text字符集合的大小

  • pdf2text的文本长度-text字符集合的大小

  • text字符集合的大小/(pdf2text的文本长度+1)

  • text空格切分后的列表大小

  • text换行符切分后的列表大小

  • -的数量

  • x的数量

  • xxx的数量

  • 数字的数量

  • @的数量

  • .com的数量

  • *的数量

  • :的数量

  • ****的数量

  • 正则匹配电话号码的数量

特征提取对应的code

pattern = r"[\D]+(1\d{10})+(?!\d)"def extract_feature_from_pdf(path):doc = fitz.open(path)all_content = []page_nums = 0for i in doc.pages():page_nums += 1all_content.append(i.get_text())text = ''.join(all_content)text = ''.join(text.split('\n'))feat = [page_nums,len(text),np.mean([len(x) for x in text.split('\n')]),np.max([len(x) for x in text.split('\n')]),np.std([len(x) for x in text.split('\n')]),len(set(text)),len(text) - len(set(text)),len(set(text)) / (len(text) + 1),len(text.split()),len(text.split('\n')),text.count('-'),text.count('x'),text.count('xxx'),sum([text.count(x) for x in '0123456789']),text.count('@'),text.count('.com'),text.count('*'),text.count(':'),text.count('****'),len(re.compile(pattern).findall(text)),1 if '正样本' in path else 0,]return feat

3.4.训练代码

本次比赛主要使用的是lightgbm的树模型,视为二分类任务,进行10折交叉验证的训练。

#!/usr/bin/env python
# _*_coding:utf-8_*_
# Author   :    Junhui Yuimport warningswarnings.simplefilter('ignore')import gcimport pandas as pdpd.set_option('display.max_columns', None)
pd.set_option('display.max_rows', 100)from sklearn.model_selection import StratifiedKFold
from sklearn.metrics import accuracy_score, classification_reportimport lightgbm as lgbimport globimport pandas as pd
from tqdm import tqdm
import numpy as np
import re
import fitzpattern = r"[\D]+(1\d{10})+(?!\d)"def extract_feature_from_pdf(path):doc = fitz.open(path)all_content = []page_nums = 0for i in doc.pages():page_nums += 1all_content.append(i.get_text())text = ''.join(all_content)text = ''.join(text.split('\n'))feat = [page_nums,len(text),np.mean([len(x) for x in text.split('\n')]),np.max([len(x) for x in text.split('\n')]),np.std([len(x) for x in text.split('\n')]),len(set(text)),len(text) - len(set(text)),len(set(text)) / (len(text) + 1),len(text.split()),len(text.split('\n')),text.count('-'),text.count('x'),text.count('xxx'),sum([text.count(x) for x in '0123456789']),text.count('@'),text.count('.com'),text.count('*'),text.count(':'),text.count('****'),len(re.compile(pattern).findall(text)),1 if '正样本' in path else 0,]return feattrain_paths = glob.glob('../xfdata/校招简历信息完整性检测训练集/*/*.pdf')df_train = pd.DataFrame(columns=['page_nums','text_len','text_len_mean','text_len_max','text_len_std','text_set_len','lentext-lenset','lenset_div_lentext','text_split_len','text_split_ent_len','-_nums','x_nums','xxx_nums','dig_sum','@_nums','.com_nums','*_nums',':_nums','****_nums','phone_nums','label'])for t_p in tqdm(train_paths):df_train.loc[len(df_train)] = extract_feature_from_pdf(t_p)not_use_feats = ['label']
use_features = [col for col in df_train.columns if col not in not_use_feats]
print(len(use_features))
train = df_train[df_train['label'].notna()]NUM_CLASSES = 2
FOLDS = 10
TARGET = 'label'def run_lgb(df_train, use_features):target = TARGEToof_pred = np.zeros((len(df_train), NUM_CLASSES))folds = StratifiedKFold(n_splits=FOLDS, shuffle=True, random_state=42)for fold, (tr_ind, val_ind) in enumerate(folds.split(train, train[TARGET])):print(f'Fold {fold + 1}')x_train, x_val = df_train[use_features].iloc[tr_ind], df_train[use_features].iloc[val_ind]y_train, y_val = df_train[target].iloc[tr_ind], df_train[target].iloc[val_ind]train_set = lgb.Dataset(x_train, y_train)val_set = lgb.Dataset(x_val, y_val)params = {'learning_rate': 0.1,'metric': 'multiclass','objective': 'multiclass','num_classes': NUM_CLASSES,'feature_fraction': 0.75,'bagging_fraction': 0.75,'bagging_freq': 2,'n_jobs': -1,'seed': 1029,'max_depth': 10,'num_leaves': 100,'lambda_l1': 0.5,'lambda_l2': 0.8,'verbose': -1}model = lgb.train(params,train_set,num_boost_round=500,early_stopping_rounds=100,valid_sets=[train_set, val_set],verbose_eval=100)oof_pred[val_ind] = model.predict(x_val)print('acc:', accuracy_score(np.argmax(oof_pred, axis=1), df_train['label']))del x_train, x_val, y_train, y_val, train_set, val_setgc.collect()return oof_pred, modeloof_pred, model = run_lgb(train, use_features)
print(classification_report(np.argmax(oof_pred, axis=1), df_train['label']))model.save_model('model.txt')

3.5.推理代码

#!/usr/bin/env python
# _*_coding:utf-8_*_
# Author   :    Junhui Yuimport globimport pandas as pd
import numpy as np
import re
import fitzimport lightgbm as lgbpatter = r"[\D]+(1\d{10})+(?!\d)"def extract_feature_from_pdf(path):doc = fitz.open(path)all_content = []page_nums = 0for i in doc.pages():page_nums += 1all_content.append(i.get_text())text = ''.join(all_content)text = ''.join(text.split('\n'))feat = [page_nums,len(text),np.mean([len(x) for x in text.split('\n')]),np.max([len(x) for x in text.split('\n')]),np.std([len(x) for x in text.split('\n')]),len(set(text)),len(text) - len(set(text)),len(set(text)) / (len(text) + 1),len(text.split()),len(text.split('\n')),text.count('-'),text.count('x'),text.count('xxx'),sum([text.count(x) for x in '0123456789']),text.count('@'),text.count('.com'),text.count('*'),text.count(':'),text.count('****'),len(re.compile(patter).findall(text)),1 if '正样本' in path else 0,]return featdf = pd.DataFrame(columns=['page_nums','text_len','text_len_mean','text_len_max','text_len_std','text_set_len','lentext-lenset','lenset_div_lentext','text_split_len','text_split_ent_len','-_nums','x_nums','xxx_nums','dig_sum','@_nums','.com_nums','*_nums',':_nums','****_nums','phone_nums','label'])test_paths = glob.glob('/work/data/integrity-check-of-resume-test-set/*.pdf')[:]for t_f in test_paths:df.loc[len(df)] = extract_feature_from_pdf(t_f)not_use_feats = ['label']
use_features = [col for col in df.columns if col not in not_use_feats]model = lgb.Booster(model_file='model.txt')y_pred = model.predict(df[use_features])predict_label = np.argmax(y_pred, axis=1)pd.DataFrame({'ResumeID': [x.split('/')[-1] for x in test_paths],'label': predict_label.astype(int)
}).to_csv('/work/output/result.csv', index=None)

3.6.特征重要度与f1-score

                feature  split       gain
16              *_nums     96  23.080862
15           .com_nums     68  15.428008
6       lentext-lenset    126  12.632440
7   lenset_div_lentext    222  10.997545
13             dig_sum    218   7.045122
1             text_len    110   4.449556
17              :_nums    179   4.178767
8       text_split_len    165   4.169549
10              -_nums    137   3.483447
5         text_set_len    184   3.018025
14              @_nums     13   2.870494
11              x_nums     94   2.141016
19          phone_nums     16   1.668496
18           ****_nums     12   1.608449
12            xxx_nums     24   1.249654
2        text_len_mean     31   1.066294
0            page_nums     31   0.803168
3         text_len_max      5   0.109109
9   text_split_ent_len      0   0.000000
4         text_len_std      0   0.000000precision    recall  f1-score   support0       0.75      0.84      0.79       1051       0.98      0.96      0.97       710accuracy                           0.94       815macro avg       0.86      0.90      0.88       815
weighted avg       0.95      0.94      0.94       815

四、延伸

本次比赛任务相对简单,如果真正做到应用级别还需要考虑更多维度综合对简历的完整性进行评价。比如:简历中核心字段的填充率、设计简历中核心字段的重要性权值等等多维度信息。涉及技术可能有基于实体识别的简历解析(从本文特征工程也可以看出)技术等。

结论

本文仅记录8月份参与该比赛思路,至于代码也很普通。该比赛任务由于比较简单,线下指标虚高,训练数据与线上评测数据较少(耐心做特征工程分数可以非常高),并且技术价值不高。因此,前前后后投入差不多一个小时左右时间速刷了一下,最后偶然获奖。

参考文献

【1】校招简历信息完整性检测挑战赛:https://challenge.xfyun.cn/topic/info?type=information-integrity&option=ssgy

这篇关于讯飞AI算法挑战大赛-校招简历信息完整性检测挑战赛-三等奖方案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

AI绘图怎么变现?想做点副业的小白必看!

在科技飞速发展的今天,AI绘图作为一种新兴技术,不仅改变了艺术创作的方式,也为创作者提供了多种变现途径。本文将详细探讨几种常见的AI绘图变现方式,帮助创作者更好地利用这一技术实现经济收益。 更多实操教程和AI绘画工具,可以扫描下方,免费获取 定制服务:个性化的创意商机 个性化定制 AI绘图技术能够根据用户需求生成个性化的头像、壁纸、插画等作品。例如,姓氏头像在电商平台上非常受欢迎,

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

从去中心化到智能化:Web3如何与AI共同塑造数字生态

在数字时代的演进中,Web3和人工智能(AI)正成为塑造未来互联网的两大核心力量。Web3的去中心化理念与AI的智能化技术,正相互交织,共同推动数字生态的变革。本文将探讨Web3与AI的融合如何改变数字世界,并展望这一新兴组合如何重塑我们的在线体验。 Web3的去中心化愿景 Web3代表了互联网的第三代发展,它基于去中心化的区块链技术,旨在创建一个开放、透明且用户主导的数字生态。不同于传统

跨国公司撤出在华研发中心的启示:中国IT产业的挑战与机遇

近日,IBM中国宣布撤出在华的两大研发中心,这一决定在IT行业引发了广泛的讨论和关注。跨国公司在华研发中心的撤出,不仅对众多IT从业者的职业发展带来了直接的冲击,也引发了人们对全球化背景下中国IT产业竞争力和未来发展方向的深思。面对这一突如其来的变化,我们应如何看待跨国公司的决策?中国IT人才又该如何应对?中国IT产业将何去何从?本文将围绕这些问题展开探讨。 跨国公司撤出的背景与

康拓展开(hash算法中会用到)

康拓展开是一个全排列到一个自然数的双射(也就是某个全排列与某个自然数一一对应) 公式: X=a[n]*(n-1)!+a[n-1]*(n-2)!+...+a[i]*(i-1)!+...+a[1]*0! 其中,a[i]为整数,并且0<=a[i]<i,1<=i<=n。(a[i]在不同应用中的含义不同); 典型应用: 计算当前排列在所有由小到大全排列中的顺序,也就是说求当前排列是第

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文

高效+灵活,万博智云全球发布AWS无代理跨云容灾方案!

摘要 近日,万博智云推出了基于AWS的无代理跨云容灾解决方案,并与拉丁美洲,中东,亚洲的合作伙伴面向全球开展了联合发布。这一方案以AWS应用环境为基础,将HyperBDR平台的高效、灵活和成本效益优势与无代理功能相结合,为全球企业带来实现了更便捷、经济的数据保护。 一、全球联合发布 9月2日,万博智云CEO Michael Wong在线上平台发布AWS无代理跨云容灾解决方案的阐述视频,介绍了

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个