`

jbpm的入门1--简单实例

    博客分类:
  • JBPM
阅读更多
这里使用的是mysql数据库
开发工具是eclipse
首先我们需要初始化话数据库
package test.config;

import org.jbpm.JbpmConfiguration;

public class InitDB {

	public static void main(String[] args) {
		InitDB initDB = new InitDB();
		initDB.createJbpmDB();
	}
	//初始化JBPM的数据库表
	public  void createJbpmDB(){
		JbpmConfiguration.getInstance().createSchema();
	}
	//删除JBPM的数据库表
	public void dropJbpmDB(){
		JbpmConfiguration.getInstance().dropSchema();
	}

}


相关的配置文件 可以在jbpm的程序包中找到
hibernate.cfg.xml要与你的数据库配置相匹配。

接下来我们绘制一个工作流,这里基本上用到jbpm的一个工作流绘制的插件。
我们绘制了一个简单的流程:
大体过程如下
起始状态--》任务1--》任务2--》结束
<?xml version="1.0" encoding="UTF-8"?>

<process-definition  xmlns=""  name="qj">


	<start-state name="start-state1">
		<transition to="apply"></transition>
	</start-state>


	<task-node name="apply">
		<task name="apply">
			<assignment actor-id="1"></assignment>
		</task>
		<transition to="approve"></transition>
	</task-node>

	<task-node name="approve">
		<task name="approve">
			<assignment actor-id="2"></assignment>
		</task>
		<transition to="end-state1"></transition>
	</task-node>


	<end-state name="end-state1"></end-state>


</process-definition>




这里的actor-id 是一个查看权限

现在我们将流程定义发布上去
package test.config;

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;

import org.jbpm.JbpmConfiguration;
import org.jbpm.JbpmContext;
import org.jbpm.graph.def.ProcessDefinition;

/**
 * 部署流程
 *
 */
public class Deploy {
	public static void main(String[] args) throws FileNotFoundException {
		JbpmContext jbpmContext = JbpmConfiguration.getInstance().createJbpmContext();
		//取得流程定义
		InputStream is = new FileInputStream("D:\\workspace\\fwk\\jbpm\\src\\test\\qj\\processdefinition.xml");
        ProcessDefinition pd = ProcessDefinition.parseXmlInputStream(is); 
		//部署流程
		jbpmContext.deployProcessDefinition(pd);
		
		jbpmContext.close();
	}
}


发布之后我们在数据库中已经可以看到相关的配置了。






下面我们创建一个流程实例。
package test;

import org.jbpm.JbpmConfiguration;
import org.jbpm.JbpmContext;
import org.jbpm.db.GraphSession;
import org.jbpm.graph.def.ProcessDefinition;
import org.jbpm.graph.exe.ProcessInstance;

public class CreatePDInstance {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		JbpmContext jbpmContext = JbpmConfiguration.getInstance().createJbpmContext();
	    GraphSession graphSession = jbpmContext.getGraphSession();
	    //取得流程定义
	    ProcessDefinition pd = graphSession.findLatestProcessDefinition("qj");
	    //创造实例
	    ProcessInstance pi = pd.createProcessInstance();
	    //token下移 刚创建的实例token是指向start-state1,我们需要让token完整这里流程 去指向真正的任务节点
	    pi.signal();
	    //当前token指向apply节点的第一个任务
	    jbpmContext.close();
	}

}






signal();方法是将状态进行转换,由于转至第二个状态,所以apply任务在结束完起始状态的时候会被同步创建创建。

由于apply任务是分配给actorId=1进行处理的,下面我们看看autorId=1的任务列表
package test;

import java.util.List;

import org.jbpm.JbpmConfiguration;
import org.jbpm.JbpmContext;
import org.jbpm.taskmgmt.exe.TaskInstance;

public class TaskActor1 {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		TaskActor1 ta1 = new TaskActor1();
		ta1.showList();

	}
	public void showList(){
		JbpmContext jbpmContext = JbpmConfiguration.getInstance().createJbpmContext();
	    String autorId="1";
	    List<TaskInstance> list = jbpmContext.getTaskList(autorId);
	    for(int i = 0 ;i<list.size();i++){
	    	TaskInstance ti = list.get(i);
	    	System.out.println("ID :" + ti.getId());
	    	System.out.println("ActorId :" + ti.getActorId());
	    	System.out.println("任务名称 :" + ti.getName());
	    	System.out.println("开始时间 :" + ti.getCreate());
	    	System.out.println("开始时间 :" + ti.getStart());
	    	System.out.println("结束时间 :" + ti.getEnd());
	    }
	}
}

我们可以看到该用户权限下的任务列表
ID :1
ActorId :1
任务名称 :apply
开始时间 :2009-06-25 16:59:05.0
开始时间 :null
结束时间 :null
下面我们开始任务该任务
我的id已经在之前获取到,这里就直接用了,实际应用中则应通过传参获取
package test;

import java.util.List;

import org.jbpm.JbpmConfiguration;
import org.jbpm.JbpmContext;
import org.jbpm.taskmgmt.exe.TaskInstance;

public class TaskActor1 {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		TaskActor1 ta1 = new TaskActor1();
		//ta1.showList();
		ta1.startTask(new Long(1));
	}
	public void showList(){
		JbpmContext jbpmContext = JbpmConfiguration.getInstance().createJbpmContext();
	    String autorId="1";
	    List<TaskInstance> list = jbpmContext.getTaskList(autorId);
	    for(int i = 0 ;i<list.size();i++){
	    	TaskInstance ti = list.get(i);
	    	System.out.println("ID :" + ti.getId());
	    	System.out.println("ActorId :" + ti.getActorId());
	    	System.out.println("任务名称 :" + ti.getName());
	    	System.out.println("开始时间 :" + ti.getCreate());
	    	System.out.println("开始时间 :" + ti.getStart());
	    	System.out.println("结束时间 :" + ti.getEnd());
	    }
	    jbpmContext.close();
	}
	public void startTask(Long i){
		JbpmContext jbpmContext = JbpmConfiguration.getInstance().createJbpmContext();
		TaskInstance ti = jbpmContext.loadTaskInstance(i);
		//如果该任务没有启动就将他启动
		if(ti.getStart() == null)
			ti.start();
		jbpmContext.close();
		showList();
	}
}

ID :1
ActorId :1
任务名称 :apply
开始时间 :2009-06-25 16:59:05.0
开始时间 :2009-06-25 19:25:52.0
结束时间 :null
此时已经开始
下面我们进行任务的完成
package test;

import java.util.List;

import org.jbpm.JbpmConfiguration;
import org.jbpm.JbpmContext;
import org.jbpm.taskmgmt.exe.TaskInstance;

public class TaskActor1 {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		TaskActor1 ta1 = new TaskActor1();
		//ta1.showList();
		//ta1.startTask(new Long(1));
		ta1.endTask(new Long(1));
	}
	public void showList(){
		JbpmContext jbpmContext = JbpmConfiguration.getInstance().createJbpmContext();
	    String autorId="1";
	    List<TaskInstance> list = jbpmContext.getTaskList(autorId);
	    for(int i = 0 ;i<list.size();i++){
	    	TaskInstance ti = list.get(i);
	    	System.out.println("ID :" + ti.getId());
	    	System.out.println("ActorId :" + ti.getActorId());
	    	System.out.println("任务名称 :" + ti.getName());
	    	System.out.println("开始时间 :" + ti.getCreate());
	    	System.out.println("开始时间 :" + ti.getStart());
	    	System.out.println("结束时间 :" + ti.getEnd());
	    }
	    jbpmContext.close();
	}
	public void startTask(Long i){
		JbpmContext jbpmContext = JbpmConfiguration.getInstance().createJbpmContext();
		TaskInstance ti = jbpmContext.loadTaskInstance(i);
		//如果该任务没有启动就将他启动
		if(ti.getStart() == null)
			ti.start();
		jbpmContext.close();
		showList();
	}
	public void endTask(Long i){
		JbpmContext jbpmContext = JbpmConfiguration.getInstance().createJbpmContext();
		TaskInstance ti = jbpmContext.loadTaskInstance(i);
		//如果该任务没有完成启动就将他完成
		if(ti.getEnd() == null)
			ti.end();
		jbpmContext.close();
		showList();
	}
}


完成之后在任务列表中已经没有任务了。
下面我们看一下数据库,第一个任务已经完成,第二个任务已经创建



接下来我们对ActorId=2的任务进行执行,等同上面的,这里不进行重复
package test;

import java.util.List;

import org.jbpm.JbpmConfiguration;
import org.jbpm.JbpmContext;
import org.jbpm.taskmgmt.exe.TaskInstance;

public class TaskActor2 {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		TaskActor2 ta2 = new TaskActor2();
		ta2.showList();
		ta2.startTask(new Long(2));
		ta2.endTask(new Long(2));
	}
	public void showList(){
		JbpmContext jbpmContext = JbpmConfiguration.getInstance().createJbpmContext();
	    String autorId="2";
	    List<TaskInstance> list = jbpmContext.getTaskList(autorId);
	    for(int i = 0 ;i<list.size();i++){
	    	TaskInstance ti = list.get(i);
	    	System.out.println("ID :" + ti.getId());
	    	System.out.println("ActorId :" + ti.getActorId());
	    	System.out.println("任务名称 :" + ti.getName());
	    	System.out.println("开始时间 :" + ti.getCreate());
	    	System.out.println("开始时间 :" + ti.getStart());
	    	System.out.println("结束时间 :" + ti.getEnd());
	    }
	    jbpmContext.close();
	}
	public void startTask(Long i){
		JbpmContext jbpmContext = JbpmConfiguration.getInstance().createJbpmContext();
		TaskInstance ti = jbpmContext.loadTaskInstance(i);
		//如果该任务没有启动就将他启动
		if(ti.getStart() == null)
			ti.start();
		jbpmContext.close();
		showList();
	}
	public void endTask(Long i){
		JbpmContext jbpmContext = JbpmConfiguration.getInstance().createJbpmContext();
		TaskInstance ti = jbpmContext.loadTaskInstance(i);
		//如果该任务没有完成启动就将他完成
		if(ti.getEnd() == null)
			ti.end();
		jbpmContext.close();
		showList();
	}
}

当第二个任务执行完成之后,你会看到任务已经整个流程已经完成,db中流程的end字段已经赋值





之所以这样分步来说,就是希望可以深入了解jbpm的执行流程
在实际的项目中往往开始和结束都是同时进行的
比如已经请假(star--填单--审批--end):往往是请假表单的填写的提交的瞬间(创建实例,填写请假单),审批的成功与否也是瞬间而且同时结束流程
即只有两步操作。
  • 大小: 24.7 KB
  • 大小: 22.7 KB
  • 大小: 32.1 KB
  • 大小: 30.6 KB
  • 大小: 42.4 KB
  • 大小: 45.8 KB
  • 大小: 32.7 KB
  • 大小: 20.6 KB
分享到:
评论

相关推荐

    逻辑编程与自动化推理:缩短证明

    本文介绍了一种扩展解析演算,基于引入新的存在量词。通过应用Q-扩展规则,可以获得多项式反驳,相较于传统的指数级解析反驳,极大地缩短了证明过程。文章详细描述了Q扩展的概念,并通过实例展示了其在简化证明中的有效性。此外,还比较了Q扩展与FR-推导和广义分解的概念,并讨论了新方法在保持可满足性等价性方面的优势。

    福昕软件阅读器的安装包

    福昕软件阅读器的安装包。

    7下-Unit1-8 单词(外研版).mp3

    7下-Unit1-8 单词(外研版).mp3

    深入浅出:PCA与KPCA数据降维技术详解,代码注释版,助力新手轻松掌握,自动导出融合特征至Excel,PCA与KPCA的深入理解与实践:详细代码注释及数据降维新手教程,实现特征融合自动导出至Exce

    深入浅出:PCA与KPCA数据降维技术详解,代码注释版,助力新手轻松掌握,自动导出融合特征至Excel,PCA与KPCA的深入理解与实践:详细代码注释及数据降维新手教程,实现特征融合自动导出至Excel文件。,主成分分析PCA、核主成分分析KPCA用于数据降维,代码注释详细,适合新手学习,可自动导出融合后的特征到excle文件 ,主成分分析PCA; 核主成分分析KPCA; 数据降维; 代码注释详细; 新手学习; 自动导出特征到excel文件,PCA与KPCA数据降维教程:代码注释详尽,适合新手,自动导出至Excel

    LC VCO电感电容压控振荡器:详细设计文档、电路文件与特性介绍,基于工艺文件介绍的高级LCVCO设计解析及其技术参数指南,LC VCO电感电容压控振荡器 LC振荡器 1.有电路文件,带工艺库PDK

    LC VCO电感电容压控振荡器:详细设计文档、电路文件与特性介绍,基于工艺文件介绍的高级LCVCO设计解析及其技术参数指南,LC VCO电感电容压控振荡器 LC振荡器 1.有电路文件,带工艺库PDK 2.有设计文档,PDF,原理和仿真介绍都有,参数设置教程,仿真状态设置 工艺:tsmc18rf 供电电压: 1.8V 中心频率: 2.4GHz 相位噪声: <-110dBc Hz 功耗: <10mW 锁相环 pll cppll ,核心关键词: 1. LC VCO电感电容压控振荡器; 2. LC振荡器; 3. 电路文件; 4. 工艺库PDK; 5. tsmc18rf; 6. 供电电压1.8V; 7. 中心频率2.4GHz; 8. 相位噪声-110dBc Hz; 9. 功耗<10mW; 10. 锁相环(PLL); 11. PLL CPPLL。,基于LC VCO电感电容压控振荡器:TSMC18RF工艺下的低功耗高稳定振荡器设计

    Comsol金属结构增强二硫化钼吸收性能的偏振依赖性研究,Comsol模拟金属结构偏振效应对二硫化钼吸收性能的增强研究,Comsol金属结构偏振依赖性增强二硫化钼吸收 ,Comsol; 金属结构;

    Comsol金属结构增强二硫化钼吸收性能的偏振依赖性研究,Comsol模拟金属结构偏振效应对二硫化钼吸收性能的增强研究,Comsol金属结构偏振依赖性增强二硫化钼吸收。 ,Comsol; 金属结构; 偏振依赖性; 二硫化钼; 吸收。,Comsol金属结构增强二硫化钼偏振依赖性吸收

    Java学生管理系统的毕业设计模板:涵盖系统设计、技术实现和测试流程

    内容概要:本文提供了Java毕业设计报告的一个模板,主要涉及一个名为“学生管理系统”的开发项目。文中详细介绍了整个项目的各个阶段及要点,包括但不限于需求分析(明确项目要解决的问题以及具体的系统功能)、系统设计方案(MVC架构的具体应用)、选用的技术及工具列表、核心功能点的技术实现方法(例如,使用Swing和JDBC完成学生的增查操作),还包括系统的初步评估,确保系统按预期工作的测试步骤及其结论,并简述了一些改进的思路以及对未来版本功能和性能的期望。

    STM32储能逆变器技术资料:原理图、PCB设计、源代码集成并网充电放电与全方位保护功能,功率达5kw,智能控制与在线升级,STM32储能逆变器技术资料:原理图、PCB与源代码集成,智能并网充电放电及

    STM32储能逆变器技术资料:原理图、PCB设计、源代码集成并网充电放电与全方位保护功能,功率达5kw,智能控制与在线升级,STM32储能逆变器技术资料:原理图、PCB与源代码集成,智能并网充电放电及全方位保护功能,功率高达5KW,STM32储能逆变器资料,提供原理图,pcb,源代码。 基于STM32F103设计,具有并网充电、放电;并网离网自动切;485通讯,在线升级;风扇智能控制,提供过流、过压、短路、过温等全方位保护。 功率5kw。 ,核心关键词:STM32F103;储能逆变器;原理图;PCB;源代码;并网充电;放电;自动切换;485通讯;在线升级;风扇控制;全方位保护;功率5kw。,STM32F103储能逆变器:5kw功率,并网智能控制,全保护通讯系统源码及设计原理

    城市群政策DID.xlsx

    家级城市群是城市发展到成熟阶段的最高空间组织形式,由在地域上集中分布的若干特大城市和大城市集聚而成的庞大的、多核心、多层次城市集团,是大都市区的联合体。 中国先后批复了10个国家级城市群:长江三角洲城市群、粤港澳大湾区、成渝城市群、长江三角洲城市群、哈长城市群、中原城市群、北部湾城市群、关中平原城市群、呼包鄂榆城市群、兰西城市群。 国家级城市群是城市发展到高级阶段的产物,具有地域集中、基础设施发达、经济联系紧密等特征,并在国家经济和社会发展中发挥着重要的战略定位和功能。 数据名称:国家级城市群政策DID 数据年份:2003-2023年 ## 02、相关数据 省份代码、省份、城市代码、城市、年份、城市群政策、政策获批时间。

    电脑直接通过RS485通讯控制伺服电机,省却PLC,LabVIEW实现Modbus控制台高效运动控制,LabVIEW直接控制伺服电机:跳过PLC,RS485通讯实现精准运动控制,LabVIEW通过mo

    电脑直接通过RS485通讯控制伺服电机,省却PLC,LabVIEW实现Modbus控制台高效运动控制,LabVIEW直接控制伺服电机:跳过PLC,RS485通讯实现精准运动控制,LabVIEW通过modbus控制台达伺服电机,不需要经过PLC,电脑通过RS485通讯直接控制伺服电机,在一些只是运动控制的项目中,可以省下买PLC的钱 ,LabVIEW; Modbus控制; 伺服电机控制; RS485通讯; 运动控制项目; PLC替代方案,LabVIEW直控伺服电机:RS485通讯,省去PLC投资成本

    基于HTML+CSS+JS的 商品购物项目.zip(毕设&课设&实训&大作业&竞赛&项目)

    项目工程资源经过严格测试运行并且功能上ok,可实现复现复刻,拿到资料包后可实现复现出一样的项目,本人系统开发经验充足(全栈全领域),有任何使用问题欢迎随时与我联系,我会抽时间努力为您解惑,提供帮助 【资源内容】:包含源码+工程文件+说明等。答辩评审平均分达到96分,放心下载使用!可实现复现;设计报告也可借鉴此项目;该资源内项目代码都经过测试运行,功能ok 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 【提供帮助】:有任何使用上的问题欢迎随时与我联系,抽时间努力解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 下载后请首先打开说明文件(如有);整理时不同项目所包含资源内容不同;项目工程可实现复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用,资源为网络商品(电子资料类)基于网络商品和电子资料商品的性质和特征不支持退款,质量优质,放心下载使用

    永磁同步电机三电平无差拍电流预测控制策略与参数辨识策略改善鲁棒性性能研究,永磁同步电机三电平无差拍电流预测控制:参数辨识策略改善鲁棒性与应对模型参数突变,永磁同步电机三电平无差拿电流预测控制,并采用参

    永磁同步电机三电平无差拍电流预测控制策略与参数辨识策略改善鲁棒性性能研究,永磁同步电机三电平无差拍电流预测控制:参数辨识策略改善鲁棒性与应对模型参数突变,永磁同步电机三电平无差拿电流预测控制,并采用参数辨识策略改善鲁棒性,电机模型参数可变,电感参数和磁链参数发生突变后,通过参数辨识策略提高鲁棒性。 ,永磁同步电机;三电平无差拍电流预测控制;参数辨识策略;鲁棒性;电机模型参数可变;电感参数突变;磁链参数突变;提高鲁棒性。,参数辨识策略优化永磁同步电机三电平无差拍电流预测控制,提升鲁棒性应对电感磁链突变

    3D结构光扫描仪,物电学院,第四届光电设计竞赛,光栅投影,格雷码.zip

    电赛

    微网优化与综合能源系统:Matlab与Cplex优化程序集成包,专业福利等你来享,微网优化与综合能源系统:Matlab与Cplex等高效工具打包福利礼物等你来领!欢呼,火火微网优化,综

    微网优化与综合能源系统:Matlab与Cplex优化程序集成包,专业福利等你来享,微网优化与综合能源系统:Matlab与Cplex等高效工具打包福利[礼物]等你来领![欢呼],[火][火]微网优化,综合能源系统优化,matlab cplex等优化程序,全部打包带走。 [钉子]福利福利 欢迎咨询[送花][送花] ,火;微网优化;综合能源系统优化;优化程序;matlab;cplex;福利咨询,火网优化全包揽:综合能源系统Cplex优化程序,Matlab解决方案大放送!

    探索硅基生命哲学与技术路径 -基于混沌-秩序理论探讨硅基生命可能性及其应用前景

    内容概要:文章介绍了作者针对硅基生命的哲学思考和技术设想。主要内容围绕如何通过混沌-秩序转化使非生命体获取生命特征展开讨论,尤其关注在人工智能环境中实现这一点的可能性,并提出了具体的实施步骤和潜在的应用场景。作者借助 deepseek 进行了一些理论测试,并得到肯定反馈,认为相关研究处于先驱地位。 适用人群:本文适合对跨学科研究感兴趣的研究者、哲学家、科学家、工程师以及关注科技发展对未来社会影响的社会各界人士。 使用场景及目标:①帮助读者理解和探索硅基生命的概念;②提供一种新的思维方式来指导未来的人工智能设计;③促进跨领域合作以进一步推进这项前沿科研项目的发展;④探讨在实际场景中的落地实施,如建立火星上的硅基生命实验场,改造火星环境,以及实现人类与硅基生命的和谐共存和互利共赢。 其他说明:虽然文中提及的内容充满想象力且具有开创意义,但作者同时也指出,许多具体细节特别是编码方面的问题尚未完善,因此需要更多专家参与才能实现最终目标。此外,该作品中融入了大量的传统文化元素和个人见解,这些都构成了独特的视角,使其既富有挑战性也颇具启发性。

    基于SSM的在线购物系统.zip(毕设&课设&实训&大作业&竞赛&项目)

    项目工程资源经过严格测试运行并且功能上ok,可实现复现复刻,拿到资料包后可实现复现出一样的项目,本人系统开发经验充足(全栈全领域),有任何使用问题欢迎随时与我联系,我会抽时间努力为您解惑,提供帮助 【资源内容】:包含源码+工程文件+说明等。答辩评审平均分达到96分,放心下载使用!可实现复现;设计报告也可借鉴此项目;该资源内项目代码都经过测试运行,功能ok 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 【提供帮助】:有任何使用上的问题欢迎随时与我联系,抽时间努力解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 下载后请首先打开说明文件(如有);整理时不同项目所包含资源内容不同;项目工程可实现复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用,资源为网络商品(电子资料类)基于网络商品和电子资料商品的性质和特征不支持退款,质量优质,放心下载使用

    北京大学-DeepSeek系列-提示词工程和落地场景

    内容概要:该文出自北京大学内部研讨会,详细讲解了 DeepSeek 提示词工程技术,涵盖了 DeepSeek 引擎的技术优势及其广泛应用场景。文章介绍了DeepSeek的特点,如模型思考过程的可视化及其在全球范围内的竞争优势(比如开源、低成本、国产化优势等)。重点讲解了几种实用的提示词技巧,例如如何让人与AI的交互更简单,如真诚直接交流、通用公式、使用「说人话」、「反向PUA」、「模仿语气」等方式提高提示词的有效性。文中提及多个DeepSeek应用实例,涵盖工作、学术及日常生活中的场景,展示了DeepSeek的多功能性及其在各个行业中的人机协作优势,包括直接使用方式(在线平台和应用程序)、提示词优化技巧及其在不同领域中的应用场景。文章的目的是让不具备专业技术背景的人也可以充分利用AI的能力。此外,提供了学习材料和技术文献供有兴趣深入了解的用户。 适用人群:适用于希望通过了解和使用 DeepSeek 技术来提高工作效率和生活质量的企业管理者、技术人员以及广大非技术用户。 使用场景及目标:①学习如何高效利用 DeepSeek 的提示词功能;②应用于专业场景如办公自动化、医学诊疗;③用于教育与培训领域以优化课堂教学;④应用于个人日常生活中,如健身计划、理财建议等;⑤探索商业创新的可能性,如电商平台优化、品牌故事叙述等。 其他说明:文中不仅包含了对 DeepSeek 功能特性的详细介绍,还有实际应用场景的成功案例分享,并提供了进一步的学习资料和在线资源供参考。通过本篇文章可以帮助读者掌握更专业的AI操作技能并为未来的研究与发展指明了方向。

Global site tag (gtag.js) - Google Analytics