PhpWord导入试卷
规定word导入格式
1、[单选题][2024][一般]题目1
A.选项1
B.选项2
C.选项3
D.选项4
答案:D
试题图片(上传多媒体图片):
分数:2
答案解析:
2、[多选题][2024][困难]题目2
A.选项1
B.选项2
C.选项3
D.选项4
E.选项5
答案:AE
分数:2
答案解析:
3、[填空题][2024][一般]题目3
答案:答案1、答案2
分数:3
答案解析:
4、[简答题][2017][一般]题目4
答案:答案内容
分数:5
设置关键词:关键词1、关键词2
答案解析:
PHP获取word内容并导入数据库的代码:
<?phppublic function import_word() {$word = "question.docx";$phpWord = \PhpOffice\PhpWord\IOFactory::load($word, 'Word2007', 'utf-8');$sections = $phpWord->getSections();$wordData = [];//将内容分句子foreach ($sections as $section) {$elements = $section->getElements();foreach ($elements as $element) {if ($element instanceof \PhpOffice\PhpWord\Element\TextRun) {$wordData[] = $element->getText();foreach($element->getElements() as $text){//导入每道题的图片if ($text instanceof \PhpOffice\PhpWord\Element\Image) {$file_path = './uploads/images'.uniqid().'.jpg';file_put_contents($file_path, trim($text->getImageString()));$wordData[] = 'image:'.Config::get('web_site_domain').ltrim($file_path, '.');} }}}}//拆分句子$questionData = [];$sectionData = [];foreach($wordData as $val){if($val){if(strpos($val, "[单选题]") !== false){if ($sectionData) {$questionData[] = $sectionData;$sectionData = [];}}else if(strpos($val, "[多选题]") !== false){if ($sectionData) {$questionData[] = $sectionData;$sectionData = [];}}else if(strpos($val, "[填空题]") !== false){if ($sectionData) {$questionData[] = $sectionData;$sectionData = [];}}else if(strpos($val, "[简答题]") !== false){if ($sectionData) {$questionData[] = $sectionData;$sectionData = [];}}$sectionData[] = $val;}}if($sectionData){$questionData[] = $sectionData;}//对试题数组过滤数据$questions = [];if ($questionData) {foreach ($questionData as $key1=>$val1) {$title = "";$answer = "";$options = "";$score = 0;$question_type = 0;$year = 0;$difficulty = 0;$question_keywords = "";$answer_key = "";$title = trim($val1[0]);$index1 = strpos($title, '[');$title = substr($title, $index1);if (strpos($title, "[单选题]") === 0) {$question_type = 1;$title = str_replace("[单选题]", "", $title);} else if (strpos($title, "[多选题]") === 0) {$question_type = 2;$title = str_replace("[多选题]", "", $title);} else if (strpos($title, "[填空题]") === 0) {$question_type = 3;$title = str_replace("[填空题]", "", $title);} else if (strpos($title, "[简答题]") === 0) {$question_type = 4;$title = str_replace("[简答题]", "", $title);}preg_match_all("/\[\d+\]/", $title, $matchs);if (isset($matchs[0][0]) && $matchs[0][0]) {$year = str_replace(["[", "]"], "", $matchs[0][0]);$title = str_replace("[{$year}]", "", $title);} else {$title = str_replace("[]", "", $title);}if (strpos($title, "[容易]") === 0) {$difficulty = 1;$title = str_replace("[容易]", "", $title);} else if (strpos($title, "[一般]") === 0) {$difficulty = 2;$title = str_replace("[一般]", "", $title);} else if (strpos($title, "[困难]") === 0) {$difficulty = 3;$title = str_replace("[困难]", "", $title);} else {$title = str_replace("[]", "", $title);}unset($val1[0]);$optionData = [];$images = [];foreach ($val1 as $k1 => $v1) {for ($i = 0; $i < 26; $i++) {$option_id = chr($i + 65).".";if (strpos($v1, $option_id) === 0) {$optionData[] = str_replace($option_id, "", $v1);}}if(strpos($v1, "image:") === 0) {$images[] = str_replace("image:", "", $v1);}if (strpos($v1, "答案:") === 0) {$answer = str_replace("答案:", "", $v1);}if (strpos($v1, "分数:") === 0) {$score = str_replace("分数:", "", $v1);}if (strpos($v1, "答案解析:") === 0) {$answer_key = str_replace("答案解析:", "", $v1);}if (strpos($v1, "设置关键词:") === 0) {$question_keywords = str_replace("设置关键词:", "", $v1);}}$question_num = $key1 + 1;//判断每道题是否符合规则if(!$title){$this->error("第".$question_num."道题【标题有误】");}if(!$question_type){$this->error("第".$question_num."道题【题型有误】");}if(!$answer){$this->error("第".$question_num."道题【答案有误】");}if(!$difficulty){$this->error("第".$question_num."道题【难度有误】");}if (in_array(trim($question_type), [1, 2])) {if(!$optionData){$this->error("第".$question_num."道题【选项有误】");}$options = [];foreach ($optionData as $k2 => $v2) {$options[$k2]['options_title'] = $v2;$options[$k2]['options_value'] = 0;}$options = FreelistoftestquestionsModel::validateAnswer($options, trim($answer));if(!$options){$this->error("第".$question_num."道题【选项有误】");}}$questions[] = ['title' => trim($title),'options' => $options,'answer' => trim($answer),'images' => implode(',', $images),'question_type' => $question_type,'year' => trim($year),'score' => intval($score),'question_keywords' => trim($question_keywords),'difficulty' => $difficulty,'answer_key' => trim($answer_key),'status' => 1,'create_time' => time(),];}}if ($questions) {if (!QuestionsModel::insertAll($questions)) {return false;}return true;} else {return false;}}
相关文章:
PhpWord导入试卷
规定word导入格式 1、[单选题][2024][一般]题目1 A.选项1 B.选项2 C.选项3 D.选项4 答案:D 试题图片(上传多媒体图片): 分数:2 答案解析: 2、[多选题][2024][困难]题目2 A.选项1 B.选项2 C.选项3 D.选项4 E…...
C# 运算符重载 之前的小总结
C# 中支持运算符重载,所谓运算符重载就是我们可以使用自定义类型来重新定义 C# 中大多数运算符的功能。运算符重载需要通过 operator 关键字后跟运算符的形式来定义的,我们可以将被重新定义的运算符看作是具有特殊名称的函数,与其他函数一样&…...
XenCenter 2024 创建一个虚拟机
前言 实现,创建一个虚拟机,内存,cpu,磁盘,名称,网卡,配置 Xen Center 2024 download 创建虚拟机 选择系统类型 定义虚拟机名称 选择ISO镜像库 选择主服务器 分配虚拟机内存,cpu资源…...
tomcat 知多少
Tomcat的缺省端口: 默认端口为8080,可以通过在tomcat安装包conf目录下,service.xml中的Connector元素的port属性来修改端口。 tomcat 常见 Connector 运行模式(优化): 这三种模式的不同之处如下: BIO : 一…...
【详细讲解语言模型的原理、实战与评估】
🌈个人主页:程序员不想敲代码啊🌈 🏆CSDN优质创作者,CSDN实力新星,CSDN博客专家🏆 👍点赞⭐评论⭐收藏 🤝希望本文对您有所裨益,如有不足之处,欢迎在评论区提…...
Predict the Next “X” ,第四范式发布先知AIOS 5.0
今天,第四范式发布了先知AIOS 5.0,一款全新的行业大模型平台。 大语言模型的原理是根据历史单词去不断预测下一个单词,换一句常见的话:Predict the Next “Word”。 当前对于行业大模型的普遍认知就是沿用这种逻辑,用大…...
PCL使用4PCS配准
一、代码 C++ #include <pcl/registration/ia_fpcs.h> // 4PCS算法 #include <pcl/point_types.h> #include <pcl/point_cloud.h> #include <pcl/io/pcd_io.h> #include <pcl/io/ply_io.h> #include <boost/thread/thread.hpp> #include…...
【六 (2)机器学习-机器学习建模步骤/kaggle房价回归实战】
一、确定问题和目标: 1、业务需求分析: 与业务团队或相关利益方进行深入沟通,了解他们的需求和期望。 分析业务流程,找出可能的瓶颈、机会或挑战。 思考机器学习如何帮助解决这些问题或实现业务目标。 2、问题定义:…...
vue源码解析——vue如何将template转换为render函数
Vue 将模板(template)转换为渲染函数(render function)是 Vue 编译器的核心功能,它是 Vue 实现响应式和虚拟 DOM 的关键步骤。在 Vue 中,模板(template)是开发者编写的类似 HTML 的代…...
深入理解zookeeper
如果是zookeeper的初学者,可以看: zookeeper快速入门(合集)-CSDN博客 如果想要深入理解zookeeper,并在面试中取得更好的表现,可以看下面的文章,都是偏面试向的角度写的。 三分钟明白zookeeper…...
【漏洞复现】WordPress Plugin LearnDash LMS 敏感信息暴漏
漏洞描述 WordPress和WordPress plugin都是WordPress基金会的产品。WordPress是一套使用PHP语言开发的博客平台。该平台支持在PHP和MySQL的服务器上架设个人博客网站。WordPress plugin是一个应用插件。 WordPress Plugin LearnDash LMS 4.10.2及之前版本存在安全漏洞&#x…...
phpmyadmin页面getshell
0x00 前言 来到phpmyadmin页面后如何getshell呢?下面介绍两种方法 0x01 select into outfile直接写入 1、利用条件 对web目录需要有写权限能够使用单引号(root) 知道网站绝对路径(phpinfo/php探针/通过报错等) secure_file_priv没有具体值 2、查看secure_file…...
题目:学习static定义静态变量的用法
题目:学习static定义静态变量的用法 There is no nutrition in the blog content. After reading it, you will not only suffer from malnutrition, but also impotence. The blog content is all parallel goods. Those who are worried about being cheate…...
【C++】编程规范之函数规则
对所有函数入参进行合法性检查 在编写函数时,应该始终对所有传入的参数进行合法性检查,以防止出现意外的错误或异常情况。这包括但不限于检查指针是否为空、整数是否在有效范围内、数组是否越界等等。通过对参数进行严格的合法性检查,可以避免…...
HTML常用的图片标签和超链接标签
目录 一.常用的图片标签和超链接标签: 1.超链接标签: 前言: 超链接的使用: target属性: 1)鼠标样式: 2)颜色及下划线: 总结: 2.图片标签: 前言: img的使用: 设置图片: 1.设置宽度和高度: 2.HTM…...
浏览器工作原理与实践--WebAPI:XMLHttpRequest是怎么实现的
在上一篇文章中我们介绍了setTimeout是如何结合渲染进程的循环系统工作的,那本篇文章我们就继续介绍另外一种类型的WebAPI——XMLHttpRequest。 自从网页中引入了JavaScript,我们就可以操作DOM树中任意一个节点,例如隐藏/显示节点、改变颜色、…...
TCP网络协议栈和Posix网络部分API总结
文章目录 Posix网络部分API综述TCP协议栈通信过程TCP三次握手和四次挥手(看下图)三次握手常见问题?为什么是三次握手而不是两次?三次握手和哪些函数有关?TCP的生命周期是从什么时候开始的? 四次挥手通信状态…...
《解释器模式(极简c++)》
本文章属于专栏- 概述 - 《设计模式(极简c版)》-CSDN博客 模式说明 方案: 对每个data建立一个单点解释器对象X,dataA和dataB之间的关系,建立一个关系解释器对象Y,这里的Y处理的是X1和X2。这样,…...
c#仿ppt案例
画曲线 namespace ppt2024 {public partial class Form1 : Form{public Form1(){InitializeComponent();}//存放所有点的位置信息List<Point> lstPosition new List<Point>();//控制开始画的时机bool isDrawing false;//鼠标点击开始画private void Form1_MouseD…...
10.图像高斯滤波的原理与FPGA实现思路
1.概念 高斯分布 图像滤波之高斯滤波介绍 图像处理算法|高斯滤波 高斯滤波(Gaussian filter)包含很多种,包括低通、高通、带通等,在图像上说的高斯滤波通常是指的高斯模糊(Gaussian Blur),是一种高斯低通滤波。通常这个算法也可以用来模…...
深度学习在微纳光子学中的应用
深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向: 逆向设计 通过神经网络快速预测微纳结构的光学响应,替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…...
手游刚开服就被攻击怎么办?如何防御DDoS?
开服初期是手游最脆弱的阶段,极易成为DDoS攻击的目标。一旦遭遇攻击,可能导致服务器瘫痪、玩家流失,甚至造成巨大经济损失。本文为开发者提供一套简洁有效的应急与防御方案,帮助快速应对并构建长期防护体系。 一、遭遇攻击的紧急应…...
React Native 开发环境搭建(全平台详解)
React Native 开发环境搭建(全平台详解) 在开始使用 React Native 开发移动应用之前,正确设置开发环境是至关重要的一步。本文将为你提供一份全面的指南,涵盖 macOS 和 Windows 平台的配置步骤,如何在 Android 和 iOS…...
Spring Boot 实现流式响应(兼容 2.7.x)
在实际开发中,我们可能会遇到一些流式数据处理的场景,比如接收来自上游接口的 Server-Sent Events(SSE) 或 流式 JSON 内容,并将其原样中转给前端页面或客户端。这种情况下,传统的 RestTemplate 缓存机制会…...
23-Oracle 23 ai 区块链表(Blockchain Table)
小伙伴有没有在金融强合规的领域中遇见,必须要保持数据不可变,管理员都无法修改和留痕的要求。比如医疗的电子病历中,影像检查检验结果不可篡改行的,药品追溯过程中数据只可插入无法删除的特性需求;登录日志、修改日志…...
系统设计 --- MongoDB亿级数据查询优化策略
系统设计 --- MongoDB亿级数据查询分表策略 背景Solution --- 分表 背景 使用audit log实现Audi Trail功能 Audit Trail范围: 六个月数据量: 每秒5-7条audi log,共计7千万 – 1亿条数据需要实现全文检索按照时间倒序因为license问题,不能使用ELK只能使用…...
鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个医院查看报告小程序
一、开发环境准备 工具安装: 下载安装DevEco Studio 4.0(支持HarmonyOS 5)配置HarmonyOS SDK 5.0确保Node.js版本≥14 项目初始化: ohpm init harmony/hospital-report-app 二、核心功能模块实现 1. 报告列表…...
大数据学习(132)-HIve数据分析
🍋🍋大数据学习🍋🍋 🔥系列专栏: 👑哲学语录: 用力所能及,改变世界。 💖如果觉得博主的文章还不错的话,请点赞👍收藏⭐️留言Ǵ…...
python报错No module named ‘tensorflow.keras‘
是由于不同版本的tensorflow下的keras所在的路径不同,结合所安装的tensorflow的目录结构修改from语句即可。 原语句: from tensorflow.keras.layers import Conv1D, MaxPooling1D, LSTM, Dense 修改后: from tensorflow.python.keras.lay…...
#Uniapp篇:chrome调试unapp适配
chrome调试设备----使用Android模拟机开发调试移动端页面 Chrome://inspect/#devices MuMu模拟器Edge浏览器:Android原生APP嵌入的H5页面元素定位 chrome://inspect/#devices uniapp单位适配 根路径下 postcss.config.js 需要装这些插件 “postcss”: “^8.5.…...
