`

kettle插件开发,json转string 格式

阅读更多
基于kettle版本5.4.0.1-130
1:实现类

2:JSONToStringMeta
说明:配置标签@Step(),初始化程序
extends BaseStepMeta :继承BaseStepMeta
implements StepMetaInterface :实现接口StepMetaInterface
整个代码的执行过程是:先运行配置标签meta类型,通过meta类找到Dialog类,当运行脚本时调用实现类
@Step(id="bsoft-json", image="JSO.png", name="JSONToString", description="json格式转string", categoryDescription="Bsoft-Dc")

public class JSONToStringMeta extends BaseStepMeta implements StepMetaInterface {
	private XMLField[] inputFields;
	private ValueMetaAndData value;
	private String outputName;

	public JSONToStringMeta() {

		super(); // allocate BaseStepInfo
	}

	//流程中新增列字段
	@SuppressWarnings("deprecation")
	@Override
	public void getFields(RowMetaInterface r, String origin, RowMetaInterface[] info, StepMeta nextStep, VariableSpace space) { 
		ValueMetaInterface v = new ValueMeta(outputName);
		v.setType(ValueMetaInterface.TYPE_STRING);
		r.addValueMeta(v);
	}

	@Override
	public Object clone() {
		JSONToStringMeta retval = (JSONToStringMeta) super.clone();
		int nrfields = inputFields.length;
		retval.allocateInput(nrfields);
		for (int i = 0; i < nrfields; i++) {
			retval.inputFields[i] = (XMLField) inputFields[i].clone();
		}

		return retval;
	}

	public void allocateInput(int nrfields) {
		inputFields = new XMLField[nrfields];
	}

	//读取ktr脚本的xml数据
	@Override
	public void loadXML(Node stepnode, List<DatabaseMeta> databases, Map<String, Counter> counters) throws KettleXMLException {
		outputName = XMLHandler.getTagValue(stepnode, "outputName"); //$NON-NLS-1$ 

		Node infields = XMLHandler.getSubNode(stepnode, "inFields"); //$NON-NLS-1$

		int num = XMLHandler.countNodes(infields, "field"); //$NON-NLS-1$

		allocateInput(num);

		for (int i = 0; i < num; i++) {
			Node fnode = XMLHandler.getSubNodeByNr(infields, "field", i); //$NON-NLS-1$ 
			inputFields[i] = new XMLField();
			inputFields[i].setType(XMLHandler.getTagValue(fnode, "type")); //$NON-NLS-1$  
			inputFields[i].setFieldName(XMLHandler.getTagValue(fnode, "name")); //$NON-NLS-1$  
			inputFields[i].setFormat(XMLHandler.getTagValue(fnode, "format")); //$NON-NLS-1$ 
			inputFields[i].setLength(Const.toInt( XMLHandler.getTagValue(fnode, "length"), -1)); //$NON-NLS-1$
			inputFields[i].setPrecision(Const.toInt( XMLHandler.getTagValue(fnode, "precision"), -1)); //$NON-NLS-1$ 

		}

	}

	//将对象Meta数据转成xml返回
	@Override
	public String getXML() {
		StringBuffer retval = new StringBuffer(300);
		retval.append("    " + XMLHandler.addTagValue("outputName", outputName == null ? "" : outputName));

		XMLField[] infields = getInputField();

		retval.append("    <inFields>"); //$NON-NLS-1$
		for (int i = 0; i < infields.length; i++) {
			inputFields[i] = infields[i];
			retval.append("      <field>"); //$NON-NLS-1$ 
			retval.append("        ").append(XMLHandler.addTagValue("name", inputFields[i].getFieldName())); //$NON-NLS-1$ //$NON-NLS-2$ 
			retval.append("        ").append(XMLHandler.addTagValue("type", inputFields[i].getTypeDesc())); //$NON-NLS-1$ //$NON-NLS-2$
			retval.append("        ").append(XMLHandler.addTagValue("format", inputFields[i].getFormat())); //$NON-NLS-1$ //$NON-NLS-2$ 
			retval.append("        ").append(XMLHandler.addTagValue("length", inputFields[i].getLength())); //$NON-NLS-1$ //$NON-NLS-2$
			retval.append("        ").append(XMLHandler.addTagValue("precision", inputFields[i].getPrecision())); //$NON-NLS-1$ //$NON-NLS-2$ 
			retval.append("      </field>"); //$NON-NLS-1$
		}
		retval.append("    </inFields>"); //$NON-NLS-1$ 

		return retval.toString();
	}
//界面调试
	@Override
	public void check(List<CheckResultInterface> remarks, TransMeta transmeta, StepMeta stepMeta, RowMetaInterface prev, String input[], String output[], RowMetaInterface info) {

		CheckResult cr;

		if (prev == null || prev.size() == 0) {

			cr = new CheckResult(CheckResultInterface.TYPE_RESULT_WARNING,

			"Not receiving any fields from previous steps!", stepMeta);

			remarks.add(cr);

		}

	}
//获得缓存中的数据
	@Override
	public void readRep(Repository rep, ObjectId id_step, List<DatabaseMeta> databases, Map<String, Counter> counters) throws KettleStepException {

		try {
			outputName = rep.getStepAttributeString(id_step, "outputName");
			int inFields = rep.countNrStepAttributes(id_step, "inFields"); //$NON-NLS-1$
			allocateInput(inFields);
			for (int i = 0; i < inFields; i++) {
				inputFields[i] = new XMLField();
				inputFields[i].setFieldName(rep.getStepAttributeString(id_step,
						i, "field_name")); //$NON-NLS-1$ 
				inputFields[i].setType(rep.getStepAttributeString(id_step, i,
						"field_type")); //$NON-NLS-1$
				inputFields[i].setFormat(rep.getStepAttributeString(id_step, i,
						"field_format")); //$NON-NLS-1$ 
				inputFields[i].setLength((int) rep.getStepAttributeInteger(
						id_step, i, "field_length")); //$NON-NLS-1$
				inputFields[i].setPrecision((int) rep.getStepAttributeInteger(
						id_step, i, "field_precision")); //$NON-NLS-1$ 
			}

		} catch (KettleException e) {
			throw new KettleStepException(e.getMessage());
		}

	}

	//保存数据到缓存中
	@Override
	public void saveRep(Repository rep, ObjectId id_transformation, ObjectId id_step) throws KettleException {
		try {
			rep.saveStepAttribute(id_transformation, id_step, "outputName", outputName);

			XMLField[] nrfields = getInputFields();

			for (int i = 0; i < nrfields.length; i++) {
				rep.saveStepAttribute(id_transformation, id_step, i,
						"field_name", nrfields[i].getFieldName()); //$NON-NLS-1$ 
				rep.saveStepAttribute(id_transformation, id_step, i,
						"field_type", nrfields[i].getTypeDesc()); //$NON-NLS-1$
				rep.saveStepAttribute(id_transformation, id_step, i,
						"field_format", nrfields[i].getFormat()); //$NON-NLS-1$ 
				rep.saveStepAttribute(id_transformation, id_step, i,
						"field_length", nrfields[i].getLength()); //$NON-NLS-1$
				rep.saveStepAttribute(id_transformation, id_step, i,
						"field_precision", nrfields[i].getPrecision()); //$NON-NLS-1$ 

			}

		} catch (KettleException e) {
			throw new KettleStepException(e.getMessage());
		}
	}

	/**
	 * @return inputFields
	 */
	public XMLField[] getInputFields() {
		return inputFields;
	}

	/**
	 * @param inputFields
	 *            inputFields
	 */
	public void setInputFields(XMLField[] inputFields) {
		this.inputFields = inputFields;
	}

	@Override
	public void setDefault() {
		int nrfields = 0;
		allocateInput(nrfields);
		XMLField[] xml = new XMLField[nrfields];
		for (int i = 0; i < nrfields; i++) {
			XMLField inPutField = new XMLField();
			xml[i] = inPutField;
		}
		setInputField(xml);

	}

	public StepDialogInterface getDialog(Shell shell, StepMetaInterface meta,
			TransMeta transMeta, String name) {

		return new JSONToStringDialog(shell, meta, transMeta, name);

	}

	@Override
	public StepInterface getStep(StepMeta stepMeta,
			StepDataInterface stepDataInterface, int cnr, TransMeta transMeta,
			Trans disp) {

		return new JSONToString(stepMeta, stepDataInterface, cnr, transMeta,
				disp);

	}

	@Override
	public StepDataInterface getStepData() {

		return new JSONToStringData();

	}

	//控制错误输出
	@Override
	public boolean supportsErrorHandling() {
		return true;
	}

	/**
	 * @return url
	 */
	public String getOutputName() {
		return outputName;
	}

	/**
	 * @param url
	 *            url
	 */
	public void setOutputName(String packageName) {
		this.outputName = packageName;
	}

	/**
	 * @return filterField
	 */
	public XMLField[] getInputField() {
		return inputFields;
	}

	/**
	 * @param filterField
	 *            filterField
	 */
	public void setInputField(XMLField[] inputFields) {
		this.inputFields = inputFields;
	}

	public ValueMetaAndData getValue() {

		return value;
	}

	public void setValue(ValueMetaAndData value) {

		this.value = value;
	}

}

3:JSONToStringData:定义共享对象类
public class JSONToStringData extends BaseStepData implements
		StepDataInterface {
	public RowMetaInterface outputRowMeta;  
	public SAXReader saxReader=null;
	public Configuration conf =null;
	public List<String> typeList=null;
	public FileSystem fs=null;
	public JSONToStringData() {
		super();  
		saxReader = new SAXReader();
		conf= new Configuration();
		typeList=new ArrayList<String>();
	}
 
}

4:JSONToStringDialog:kettle的ui管理界面
说明:extends BaseStepDialog implements StepDialogInterface

public class JSONToStringDialog extends BaseStepDialog implements StepDialogInterface {
	private static Class<?> PKG = JSONToStringMeta.class; // for i18n
	private JSONToStringMeta input;
 
	 
	private ModifyListener lsMod;
	
	private CTabFolder   wTabFolder;
	private FormData     fdTabFolder;
	
	private CTabItem      inputTab,outputTab,dbTab;
	private MessageBox msgError; 
	 

	private Label className_lable;
	private CCombo  className_text;  
	private FormData className_lform, className_tform;
	
	private Label input_lable;
	private TableView input_view;
	private FormData input_lform, input_tform; 
	 
	
	public JSONToStringDialog(Shell parent, Object in, TransMeta transMeta, String sname)
	{
		super(parent, (BaseStepMeta) in, transMeta, sname); 
		input = (JSONToStringMeta) in; 
	}

	@Override
	public String open()

	{// 初始化控制台

		Shell parent = getParent();
		Display display = parent.getDisplay();
		
		shell = new Shell(parent, SWT.DIALOG_TRIM | SWT.RESIZE | SWT.MAX | SWT.MIN);
 		props.setLook(shell);
        setShellImage(shell, input);
 		
		lsMod = new ModifyListener() 
		{
			@Override
			public void modifyText(ModifyEvent e) 
			{
				input.setChanged();
			}
		};
		changed = input.hasChanged();

		FormLayout formLayout = new FormLayout ();
		formLayout.marginWidth  = Const.FORM_MARGIN;
		formLayout.marginHeight = Const.FORM_MARGIN;

		shell.setLayout(formLayout);
		shell.setText("json转string"); //$NON-NLS-1$
		
		int middle = props.getMiddlePct();
		int margin = Const.MARGIN;
		
 

		// 参数输入
		wlStepname=new Label(shell, SWT.RIGHT);
		wlStepname.setText("名称"); //$NON-NLS-1$
		props.setLook(wlStepname);
		fdlStepname=new FormData();
		fdlStepname.left = new FormAttachment(0, 0);
		fdlStepname.right = new FormAttachment(middle, -margin);
		fdlStepname.top = new FormAttachment(0, 0);
		wlStepname.setLayoutData(fdlStepname);
		wStepname=new Text(shell, SWT.SINGLE | SWT.LEFT | SWT.BORDER);
		wStepname.setText(stepname);
 		props.setLook(wStepname);
		wStepname.addModifyListener(lsMod);
		fdStepname=new FormData();
		fdStepname.left = new FormAttachment(middle, 0);
		fdStepname.top  = new FormAttachment(0, margin);
		fdStepname.right= new FormAttachment(100, 0);
		wStepname.setLayoutData(fdStepname);
		
		wTabFolder = new CTabFolder(shell, SWT.BORDER);
 		props.setLook(wTabFolder, Props.WIDGET_STYLE_TAB);
 		wTabFolder.setSimple(false);
 		
		FormLayout fieldsLayout = new FormLayout ();
		fieldsLayout.marginWidth  = Const.FORM_MARGIN;
		fieldsLayout.marginHeight = Const.FORM_MARGIN;
		
		Composite inputComp = new Composite(wTabFolder, SWT.NONE);
		inputComp.setLayout(fieldsLayout);
 		props.setLook(inputComp);
 		
 		inputTab = new CTabItem(wTabFolder, SWT.NONE);
 		inputTab.setText("参数输入");
		
 		inputComp.layout();
		inputTab.setControl(inputComp);

		fdTabFolder = new FormData();
		fdTabFolder.left  = new FormAttachment(0, 0);
		fdTabFolder.top   = new FormAttachment(wStepname, margin);
		fdTabFolder.right = new FormAttachment(100, 0);
		fdTabFolder.bottom= new FormAttachment(100, -50);
		wTabFolder.setLayoutData(fdTabFolder); 
		   
		//输入包路径
		className_lable = new Label(inputComp, SWT.RIGHT);
		className_lable.setText("输出字段:"); 
		props.setLook(className_lable);
		className_lform = new FormData();
		className_lform.left = new FormAttachment(0, 0);
		className_lform.right = new FormAttachment(middle, -margin);
		className_lform.top = new FormAttachment(wOK, margin);
		className_lable.setLayoutData(className_lform); 
		className_text = new CCombo(inputComp, SWT.SINGLE | SWT.LEFT | SWT.BORDER);
		props.setLook(className_text);
		className_text.addModifyListener(lsMod);
		className_tform = new FormData();
		className_tform.left = new FormAttachment(middle, 0);
		className_tform.right = new FormAttachment(100, 0);
		className_tform.top = new FormAttachment(wOK, margin);
		className_text.setLayoutData(className_tform);  
	    
		input_lable=new Label(inputComp, SWT.NONE);
		input_lable.setText("输入参数配置:"); //$NON-NLS-1$
		props.setLook(input_lable);
		input_lform=new FormData();
		input_lform.left  = new FormAttachment(0, 0);
		input_lform.right = new FormAttachment(100, 0);
		input_lform.top   = new FormAttachment(className_text, -margin+2);
		input_lable.setLayoutData(input_lform);
		
		int FieldsRows=0;
		if(input.getInputField()!=null){
			FieldsRows=input.getInputField().length;
		}
		
		//
		ColumnInfo[] colinf = new ColumnInfo[] {
				new ColumnInfo("字段", ColumnInfo.COLUMN_TYPE_CCOMBO, setRowMeta()), //$NON-NLS-1$
				new ColumnInfo("改名为", ColumnInfo.COLUMN_TYPE_TEXT, false), //$NON-NLS-1$
				new ColumnInfo("类型", ColumnInfo.COLUMN_TYPE_CCOMBO, ValueMeta.getTypes()), //$NON-NLS-1$
				new ColumnInfo("长度", ColumnInfo.COLUMN_TYPE_TEXT, false), //$NON-NLS-1$
				new ColumnInfo("精度", ColumnInfo.COLUMN_TYPE_TEXT, false), //$NON-NLS-1$ 
			}; 
		
		input_view = new TableView(transMeta, inputComp, SWT.BORDER
				| SWT.FULL_SELECTION | SWT.MULTI | SWT.V_SCROLL | SWT.H_SCROLL, colinf, FieldsRows, lsMod,
				props);

		input_tform = new FormData();
		input_tform.left = new FormAttachment(0, 0);
		input_tform.top = new FormAttachment(input_lable, margin);
		input_tform.right = new FormAttachment(100, 0);
		input_tform.bottom = new FormAttachment(100, 0);
		input_view.setLayoutData(input_tform);
		 
 
		wOK=new Button(shell, SWT.PUSH);
		wOK.setText(BaseMessages.getString(PKG, "System.Button.OK"));

		wCancel=new Button(shell, SWT.PUSH);
		wCancel.setText(BaseMessages.getString(PKG, "System.Button.Cancel"));

		setButtonPositions(new Button[] { wOK, wCancel }, margin, wTabFolder);
		
		msgError = new MessageBox(shell, SWT.ICON_ERROR);
		
		setSize();
		initInfo();
		Listener lsCancel = new Listener() {
			@Override
			public void handleEvent(Event e) {
				cancel();
			}
		};

		Listener lsOk = new Listener() {
			@Override
			public void handleEvent(Event e) {
				ok();
			}
		}; 
		
		wCancel.addListener(SWT.Selection, lsCancel);
		
		wOK.addListener(SWT.Selection, lsOk);  
		
		wTabFolder.setSelection(0);
		
		shell.open();

		
		setRowMeta();
		 
		
		while (!shell.isDisposed()) 
		{ 
			if (!display.readAndDispatch())
				display.sleep(); 
		}

		return stepname;

	}   
	
	private String[] getDBMeta(){ 
        
		 return transMeta.getDatabaseNames();
	 
	}
	//初始化数据
	private void initInfo(){ 
		if(input.getOutputName()==null){  
			className_text.setText("");
		}else{
			className_text.setText(input.getOutputName());
		}
		 
		 
		
		XMLField[] nrfields = input.getInputField();  
		
		for (int i = 0; i < nrfields.length; i++) {
			XMLField field = nrfields[i];
			TableItem item = input_view.table.getItem(i); 
            if (field.getFieldName()!=null) item.setText(1, field.getFieldName()); 
            if (field.getFormat()!=null) item.setText(2, field.getFormat());
            item.setText(3, field.getTypeDesc());
            if (field.getLength()>=0) item.setText(4, ""+field.getLength());
            if (field.getPrecision()>=0) item.setText(5, ""+field.getPrecision()); 
		}    
 
		 
		
	}   
	//设置列名
	private String[] setRowMeta() {
		String[] rowNames = null;
		StepMeta stepMeta = transMeta.findStep(stepname);
		if (stepMeta != null) {
			try {
				RowMetaInterface row = transMeta.getPrevStepFields(stepMeta);
				if (row == null) {
					return null;

				}
				rowNames = new String[row.size()]; 
				for (int i = 0; i < row.size(); i++) {
					rowNames[i] = row.getValueMeta(i).getName();
				}
			} catch (KettleException e) {
				logError(BaseMessages.getString(PKG, "System.Dialog.GetFieldsFailed.Message"));
			}
		}
		return rowNames;
	}
		
	private void cancel()

	{  
		dispose();

	} 
	//点击确定按钮操作,并保存数据
	private void ok() 
	{ 
		 
		if (!"".equals(className_text.getText())) 
		{   
			
			input.setOutputName(className_text.getText());
			 
			int infields = input_view.nrNonEmpty();
			input.allocateInput(infields);
			 
	        for (int i=0;i<infields;i++)
	        {
	            XMLField field = new XMLField(); 
	            TableItem item = input_view.getNonEmpty(i);
	            field.setFieldName( item.getText(1) );  
	            field.setFormat( item.getText(2) );
	            field.setType( item.getText(3) );
	           
	            field.setLength( Const.toInt(item.getText(4), -1) );
	            field.setPrecision( Const.toInt(item.getText(5), -1) ); 
	            input.getInputFields()[i]  = field;
	        }  
	    	 
		    dispose();

			return;

		}else{
			   msgError.setMessage("请输入需要解析的对象"); 
		} 
		msgError.setMessage("请输入需要解析的对象");

		msgError.open();
//
	} 
}

5:JSONToString
说明:实现json转string
public boolean processRow(StepMetaInterface smi, StepDataInterface sdi) throws KettleException
	{  
		meta = (JSONToStringMeta) smi;
		data = (JSONToStringData) sdi;
		//获得转换流程中的数据
		Object[] row = getRow();   
		if (row == null)   
		{
			setOutputDone(); 
			return false; 
		} 
		// 初始数据
		if (first) 
		{ 
			first = false; 
			//获得转换流程中的例字段
			data.outputRowMeta = getInputRowMeta().clone(); 
			//往转换流程中新增字段
			meta.getFields(data.outputRowMeta, getStepname(), null, null, this); 
		} 
		if(meta.getOutputName()==null){
			logError("no find class,class name  is ["+meta.getOutputName()+ "]");
			return false;
		}  
		String msg = "Success";
		String code = "200"; 
		Map<String, Object> res = new  HashMap<String, Object>(); 
		res.put(RES_CODE, code);
		res.put(RES_MESSAGE, msg); 
		Map<String,Object> items=getInputRows(  row); 
		//格式转换
		String out=JSON.toJSONString(items);
		//往转换流程中新增数据
		Object[] outData = RowDataUtil.addValueData(row, getInputRowMeta().size(), out); 
		getRes(res, outData, row); 
		return true;
	}   
  • 大小: 8.4 KB
  • 大小: 21.8 KB
分享到:
评论

相关推荐

    kettle解析json串

    - Kettle支持多种数据源,包括关系型数据库、XML、CSV等格式的数据文件,以及复杂的JSON文件。 #### 2. **JSON解析的重要性** - JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于人阅读和...

    kafka生产者消费者插件 steps.zip

    3. **数据格式支持**:Kafka插件通常支持多种数据格式,如JSON、Avro、String等,这样可以方便地与各种类型的数据源和目标进行交互。 4. **错误处理与日志记录**:Kettle的Kafka插件还可能包含错误处理机制,例如...

    mysql8.0.31连接jar包

    在实际开发中,你可能还需要关注JDBC连接池的使用,比如HikariCP或Apache Commons DBCP,它们能有效管理数据库连接,提高应用的效率和响应速度。同时,了解如何处理事务、异常和并发操作也是使用MySQL JDBC驱动时不...

    一个基于Qt Creator(qt,C++)实现中国象棋人机对战

    qt 一个基于Qt Creator(qt,C++)实现中国象棋人机对战.

    热带雨林自驾游自然奇观探索.doc

    热带雨林自驾游自然奇观探索

    冰川湖自驾游冰雪交融景象.doc

    冰川湖自驾游冰雪交融景象

    C51 单片机数码管使用 Keil项目C语言源码

    C51 单片机数码管使用 Keil项目C语言源码

    基于智能算法的无人机路径规划研究 附Matlab代码.rar

    1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。

    前端分析-2023071100789s12

    前端分析-2023071100789s12

    Delphi 12.3控件之Laz-制作了一些窗体和对话框样式.7z

    Laz_制作了一些窗体和对话框样式.7z

    ocaml-docs-4.05.0-6.el7.x64-86.rpm.tar.gz

    1、文件内容:ocaml-docs-4.05.0-6.el7.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/ocaml-docs-4.05.0-6.el7.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、更多资源/技术支持:公众号禅静编程坊

    学习笔记-沁恒第六讲-米醋

    学习笔记-沁恒第六讲-米醋

    工业机器人技术讲解【36页】.pptx

    工业机器人技术讲解【36页】

    基于CentOS 7和Docker环境下安装和配置Elasticsearch数据库

    内容概要:本文档详细介绍了在 CentOS 7 上利用 Docker 容器化环境来部署和配置 Elasticsearch 数据库的过程。首先概述了 Elasticsearch 的特点及其主要应用场景如全文检索、日志和数据分析等,并强调了其分布式架构带来的高性能与可扩展性。之后针对具体的安装流程进行了讲解,涉及创建所需的工作目录,准备docker-compose.yml文件以及通过docker-compose工具自动化完成镜像下载和服务启动的一系列命令;同时对可能出现的问题提供了应对策略并附带解决了分词功能出现的问题。 适合人群:从事IT运维工作的技术人员或对NoSQL数据库感兴趣的开发者。 使用场景及目标:该教程旨在帮助读者掌握如何在一个Linux系统中使用现代化的应用交付方式搭建企业级搜索引擎解决方案,特别适用于希望深入了解Elastic Stack生态体系的个人研究与团队项目实践中。 阅读建议:建议按照文中给出的具体步骤进行实验验证,尤其是要注意调整相关参数配置适配自身环境。对于初次接触此话题的朋友来说,应该提前熟悉一下Linux操作系统的基础命令行知识和Docker的相关基础知识

    基于CNN和FNN的进化神经元模型的快速响应尖峰神经网络 附Matlab代码.rar

    1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。

    网络小说的类型创新、情节设计与角色塑造.doc

    网络小说的类型创新、情节设计与角色塑造

    毕业设计-基于springboot+vue开发的学生考勤管理系统【源码+sql+可运行】50311.zip

    毕业设计_基于springboot+vue开发的学生考勤管理系统【源码+sql+可运行】【50311】.zip 全部代码均可运行,亲测可用,尽我所能,为你服务; 1.代码压缩包内容 代码:springboo后端代码+vue前端页面代码 脚本:数据库SQL脚本 效果图:运行结果请看资源详情效果图 2.环境准备: - JDK1.8+ - maven3.6+ - nodejs14+ - mysql5.6+ - redis 3.技术栈 - 后台:springboot+mybatisPlus+Shiro - 前台:vue+iview+Vuex+Axios - 开发工具: idea、navicate 4.功能列表 - 系统设置:用户管理、角色管理、资源管理、系统日志 - 业务管理:班级信息、学生信息、课程信息、考勤记录、假期信息、公告信息 3.运行步骤: 步骤一:修改数据库连接信息(ip、port修改) 步骤二:找到启动类xxxApplication启动 4.若不会,可私信博主!!!

    57页-智慧办公园区智能化设计方案.pdf

    在智慧城市建设的大潮中,智慧园区作为其中的璀璨明珠,正以其独特的魅力引领着产业园区的新一轮变革。想象一下,一个集绿色、高端、智能、创新于一体的未来园区,它不仅融合了科技研发、商业居住、办公文创等多种功能,更通过深度应用信息技术,实现了从传统到智慧的华丽转身。 智慧园区通过“四化”建设——即园区运营精细化、园区体验智能化、园区服务专业化和园区设施信息化,彻底颠覆了传统园区的管理模式。在这里,基础设施的数据收集与分析让管理变得更加主动和高效,从温湿度监控到烟雾报警,从消防水箱液位监测到消防栓防盗水装置,每一处细节都彰显着智能的力量。而远程抄表、空调和变配电的智能化管控,更是在节能降耗的同时,极大地提升了园区的运维效率。更令人兴奋的是,通过智慧监控、人流统计和自动访客系统等高科技手段,园区的安全防范能力得到了质的飞跃,让每一位入驻企业和个人都能享受到“拎包入住”般的便捷与安心。 更令人瞩目的是,智慧园区还构建了集信息服务、企业服务、物业服务于一体的综合服务体系。无论是通过园区门户进行信息查询、投诉反馈,还是享受便捷的电商服务、法律咨询和融资支持,亦或是利用云ERP和云OA系统提升企业的管理水平和运营效率,智慧园区都以其全面、专业、高效的服务,为企业的发展插上了腾飞的翅膀。而这一切的背后,是大数据、云计算、人工智能等前沿技术的深度融合与应用,它们如同智慧的大脑,让园区的管理和服务变得更加聪明、更加贴心。走进智慧园区,就像踏入了一个充满无限可能的未来世界,这里不仅有科技的魅力,更有生活的温度,让人不禁对未来充满了无限的憧憬与期待。

    一种欠定盲源分离方法及其在模态识别中的应用 附Matlab代码.rar

    1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。

    Matlab实现基于BO贝叶斯优化Transformer结合GRU门控循环单元时间序列预测的详细项目实例(含完整的程序,GUI设计和代码详解)

    内容概要:本文介绍了使用 Matlab 实现基于 BO(贝叶斯优化)的 Transformer 结合 GRU 门控循环单元时间序列预测的具体项目案例。文章首先介绍了时间序列预测的重要性及其现有方法存在的限制,随后深入阐述了该项目的目标、挑战与特色。重点描述了项目中采用的技术手段——结合 Transformer 和 GRU 模型的优点,通过贝叶斯优化进行超参数调整。文中给出了模型的具体实现步骤、代码示例以及完整的项目流程。同时强调了数据预处理、特征提取、窗口化分割、超参数搜索等关键技术点,并讨论了系统的设计部署细节、可视化界面制作等内容。 适合人群:具有一定机器学习基础,尤其是熟悉时间序列预测与深度学习的科研工作者或从业者。 使用场景及目标:适用于金融、医疗、能源等多个行业的高精度时间序列预测。该模型可通过捕捉长时间跨度下的复杂模式,提供更为精准的趋势预判,辅助相关机构作出合理的前瞻规划。 其他说明:此项目还涵盖了从数据采集到模型发布的全流程讲解,以及GUI图形用户界面的设计实现,有助于用户友好性提升和技术应用落地。此外,文档包含了详尽的操作指南和丰富的附录资料,包括完整的程序清单、性能评价指标等,便于读者动手实践。

Global site tag (gtag.js) - Google Analytics