- 浏览: 147414 次
- 来自: ...
文章分类
- 全部博客 (56)
- JSF (8)
- 励志与成功 (1)
- 数据库 (5)
- Web开发 (4)
- Solution (6)
- Spring (2)
- SVN 删除文件 (1)
- SVN 问题 (1)
- java Timer (1)
- JSP Flex (1)
- Java String (1)
- webservice (1)
- JAVA DB Connection Pool (1)
- WSDL2Java (1)
- marshaller/Unmarshaller (1)
- Refactor (1)
- JS (2)
- Java Unicode (1)
- Tiles (1)
- Struts1.x (1)
- 经理人 (1)
- Spring+Hibernate (1)
- Spring Test (1)
- Ajax Javascript (1)
- Oracle account locked (0)
- REST (2)
- REST Automation Testing (1)
- 项目管理 (2)
- JAVA开发 (2)
- Groovy (1)
- 开源软件 (1)
- Hibernate (2)
最新评论
-
hanmiao:
我在这里找到了问题的答案:https://subversion ...
SVN版本控制中的“同名受版本控制的目录已存在”问题及解决办法 -
jidu01:
没明白后面的一段,LZ 能否详细说一下呢。怎样删除XSD,又怎 ...
Unmarshaller异常javax.xml.bind.UnmarshalException: unexpected element处理方法
在Java开发过程中经常会遇到字符处理的问题,比如接收到xml格式的字符串,需要把它转换成对象。对象需要转化成xml字符串发送出去。
这里收藏两篇文章供日后参考。
1.利用jdom把xml字符串转化为对象
JAVA解析XML格式字符串
http://zhenhu5131420.blog.163.com/blog/static/439143252009102351346784/
http://blog.sina.com.cn/s/blog_700dec940100spox.html
package com.freesky.xml;
import java.io.File;
import java.io.FileNotFoundException;
import
java.io.FileReader;
import java.io.IOException;
import java.io.StringReader;
import
java.util.List;
import org.jdom.Document;
import org.jdom.Element;
import
org.jdom.JDOMException;
import org.jdom.Namespace;
import
org.jdom.input.SAXBuilder;
import org.xml.sax.InputSource;
public class DuXMLDoc {
public List xmlElements(String xmlDoc)
{
//创建一个新的字符串
StringReader read = new
StringReader(xmlDoc);
//创建新的输入源SAX 解析器将使用 InputSource 对象来确定如何读取 XML
输入
InputSource source = new InputSource(read);
//创建一个新的SAXBuilder
SAXBuilder sb = new SAXBuilder();
try
{
//通过输入源构造一个Document
Document doc =
sb.build(source);
//取的根元素
Element root =
doc.getRootElement();
System.out.println(root.getName());//输出根元素的名称(测试)
//得到根元素所有子元素的集合
List jiedian = root.getChildren();
//获得XML中的命名空间(XML中未定义可不写)
Namespace ns =
root.getNamespace();
Element et = null;
for(int
i=0;i<jiedian.size();i++){
et = (Element)
jiedian.get(i);//循环依次得到子元素
System.out.println(et.getChild("users_id",ns).getText());
System.out.println(et.getChild("users_address",ns).getText());
}
et = (Element) jiedian.get(0);
List zjiedian = et.getChildren();
for(int
j=0;j<zjiedian.size();j++){
Element xet = (Element)
zjiedian.get(j);
System.out.println(xet.getName());
}
} catch
(JDOMException e) {
// TODO 自动生成 catch 块
e.printStackTrace();
} catch (IOException e) {
// TODO
自动生成 catch 块
e.printStackTrace();
}
return
null;
}
public static void main(String[] args){
DuXMLDoc doc = new DuXMLDoc();
// String xml = "<?xml
version=\"1.0\" encoding=\"gb2312\"?>"+
// "<Result xmlns=\"http://www.fiorano.com/fesb/activity/DBQueryOnInput2/Out\">"+
//
"<row resultcount=\"1\">"+
// "<users_id>1001
</users_id>"+
// "<users_name>wangwei
</users_name>"+
// "<users_group>80
</users_group>"+
// "<users_address>1001号
</users_address>"+
// "</row>"+
//
"<row resultcount=\"1\">"+
// "<users_id>1002
</users_id>"+
// "<users_name>wangwei
</users_name>"+
// "<users_group>80
</users_group>"+
// "<users_address>1002号
</users_address>"+
// "</row>"+
//
"</Result>";
// doc.xmlElements(xml);
File file = new File("./xml/outparam.xml");
try {
FileReader fr
= new FileReader(file);
char[] values = new char[800];
int length =
fr.read(values);
String s = new String(values, 0 ,
length);
System.out.println(s);
} catch (FileNotFoundException
e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
catch (IOException e) {
e.printStackTrace();
}
}
}
2.自定义格式,把对象转换成xml字符串。
Java生成XML格式的字符串
http://padden.blog.51cto.com/2514314/578685
package com.freesky.xml;
import java.util.ArrayList;
import java.util.Iterator;
import
java.util.List;
/**
* 根据该对象可以构造Xml字符串
*
*
*/
public class XmlObject
{
private static String HEAD = "<?xml version=\"1.0\"
encoding=\"utf-8\"?>";
private String name;
private Object
value;
private List<Attribute> attributes;
private
List<XmlObject> subXmlObjects;
public static void
main(String[] args) {
XmlObject xmlObject = new
XmlObject("deviceparams");
xmlObject.setAttribute("type",
"input");
xmlObject.setAttribute("id", "123123123");
XmlObject
paramObject = new XmlObject("param");
paramObject.setAttribute("name",
"techtype");
paramObject.setAttribute("value",
"HW123");
xmlObject.addSubXmlObject(paramObject);
XmlObject
inputObject = new
XmlObject("inputparams");
inputObject.addSubXmlObject(paramObject);
xmlObject.addSubXmlObject(inputObject);
System.out.println(xmlObject.toFormatXml());
}
/**
* 根据name构造XmlObject
*
* @param name
*
生成xml时标签名,如name="html",则生成xml为<html/>
*/
public XmlObject(String
name) {
this.name = name;
}
/**
* 获得当前对象的名称
*
* @return 返回当前对象的名称
*/
public
final String getName() {
return name;
}
/**
* 设置当前对象的名称
*
* @param name
* 给定名称
*/
public final void setName(String name) {
this.name = name;
}
/**
* 获得当前对象的值
*
* @return 返回当前对象的值
*/
public final
Object getValue() {
return value;
}
/**
* 设置当前对象的值
*
* @param value
* 给定值
*/
public final void setValue(Object value) {
this.value =
value;
}
/**
* 为当前XmlObject添加属性
*
* @param name
*
属性名
* @param value
* 属性值
*/
public final void
setAttribute(String name, Object value) {
if (attributes == null)
{
attributes = new ArrayList<Attribute>();
}
Attribute
attribute = null;
for (Attribute att : attributes) {
if
(name.equalsIgnoreCase(att.getName())) {
attribute =
att;
break;
}
}
if (attribute == null) {
attribute
= new Attribute(name, value);
attributes.add(attribute);
} else
{
attribute.setValue(value);
}
}
/**
* 根据属性名称获得当前XmlObject对象的属性值
*
* @param name
* 属性名称
* @return 属性值
*/
public final Object
getAttributeValue(String name) {
return getAttributeValue(name,
null);
}
/**
* 根据属性名称获得当前XmlObject对象的属性值
*
* @param name
* 属性名称
* @param defaultValue
* 默认值
*
@return 若属性存在,则返回属性值,否则返回默认值
*/
public final Object
getAttributeValue(String name, Object defaultValue) {
Attribute attribute =
null;
for (Attribute att : attributes) {
if
(name.equalsIgnoreCase(att.getName())) {
attribute =
att;
break;
}
}
if (attribute == null) {
return
defaultValue;
} else {
return attribute.getValue();
}
}
/**
* 为当前XmlObject对象添加子XmlObject对象
*
* @param xmlObject
* 给定XmlObject对象
*/
public final void
addSubXmlObject(XmlObject xmlObject) {
if (subXmlObjects == null)
{
subXmlObjects = new
ArrayList<XmlObject>();
}
subXmlObjects.add(xmlObject);
}
/**
* 构造当前对象的压缩XML字符串
*
* @return XML字符串
*/
public
final String toCompactXml() {
return HEAD + getNoHeadXml("", "");
}
/**
* 根据格式化留白("\t")和默认的行分隔符("\t")构造当前对象的XML字符串
*
* @return
XML字符串
*/
public String toFormatXml() {
return
toFormatXml("\t");
}
/**
* 根据格式化留白和默认的行分隔符("\n")构造当前对象的XML字符串
*
* @param
blank
* 格式化留白
* @return XML字符串
*/
protected final
String toFormatXml(String blank) {
return HEAD + "\n" + getNoHeadXml(blank,
"\n");
}
/**
* 根据格式化留白和行分隔符构造当前对象的无头的XML字符串
*
* @param blank
* 格式化留白
* @param split
* 行分隔符
* @return
无头的XML字符串
*/
protected final String getNoHeadXml(String blank, String
split) {
return getNoHeadXml(blank, split, 0);
}
private final String getNoHeadXml(String blank, String split, int count)
{
String blanks = "";
for (int i = 0; i < count; i++)
{
blanks += blank;
}
StringBuffer sb = new
StringBuffer();
sb.append(blanks + "<" + name);
if (attributes !=
null) {
Iterator<Attribute> iterator =
attributes.iterator();
while (iterator.hasNext()) {
Attribute
attribute = iterator.next();
sb.append(" " + attribute.getName() +
"=\""
+ attribute.getValue() + "\"");
}
}
if
(subXmlObjects == null) {
if (value == null) {
sb.append("/>" +
split);
} else
{
sb.append(">");
sb.append(value);
sb.append("</" +
name + ">" + split);
}
} else {
sb.append(">" +
split);
Iterator<XmlObject> iterator =
subXmlObjects.iterator();
count += 1;
while (iterator.hasNext())
{
XmlObject xmlObject =
iterator.next();
sb.append(xmlObject.getNoHeadXml(blank, split,
count));
}
sb.append(blanks + "</" + name + ">" +
split);
}
return sb.toString();
}
class Attribute {
private String name;
private Object value;
public Attribute(String name, Object value) {
this.name =
name;
this.value = value;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Object getValue() {
return value;
}
public void setValue(Object value) {
this.value =
value;
}
}
}
3. 利用JDK1.5中javax.xml包对字符串进行处理,其中提供了DOM解析和SAX解析。下面这个例子演示了如何解析xml文件,如何构造xml字符串,以及如何解析xml字符串 。
package com.freesky.xml;
/** 要读的xml文件
<?xml version="1.0" encoding="GB2312"?>
<学生花名册>
<学生 性别
=
"男">
<姓名>李华</姓名>
<年龄>14</年龄>
</学生>
<学生
性别 = "男">
<姓名>张三</姓名>
<年龄>16</年龄>
</学生>
</学生花名册>
*/
import java.io.ByteArrayInputStream;
import
java.io.ByteArrayOutputStream;
import java.io.InputStream;
import
java.io.OutputStreamWriter;
import java.util.Iterator;
import
java.util.Vector;
import javax.xml.parsers.DocumentBuilder;
import
javax.xml.parsers.DocumentBuilderFactory;
import
javax.xml.transform.OutputKeys;
import javax.xml.transform.Result;
import
javax.xml.transform.Source;
import javax.xml.transform.Transformer;
import
javax.xml.transform.TransformerConfigurationException;
import
javax.xml.transform.TransformerException;
import
javax.xml.transform.TransformerFactory;
import
javax.xml.transform.dom.DOMSource;
import
javax.xml.transform.stream.StreamResult;
import
org.w3c.dom.Document;
import org.w3c.dom.Element;
import
org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import
org.w3c.dom.Text;
public class DomTest {
Vector<Student> students_Vector;
/**
* 功能:读取XML文件中的信息
*/
public Vector<Student>
readXMLFile(String file) throws Exception {
DocumentBuilderFactory dbf =
DocumentBuilderFactory.newInstance();
DocumentBuilder builder =
dbf.newDocumentBuilder();
Document doc = builder.parse(file); //
获取到xml文件
// 下面开始读取
loadDocument(doc);
return
students_Vector;
}
/**
* 功能:直接提取XML格式字符串中的信息
*/
public Vector<Student>
readXMLString(String xmlStr) throws Exception {
DocumentBuilderFactory dbf
= DocumentBuilderFactory.newInstance();
DocumentBuilder builder =
dbf.newDocumentBuilder();
InputStream inputStream = new
ByteArrayInputStream(xmlStr.getBytes());
Document doc =
builder.parse(inputStream); //
//
下面开始读取
loadDocument(doc);
return
students_Vector;
}
private void loadDocument(Document doc)
{
// 下面开始读取
Element root = doc.getDocumentElement(); //
获取根元素
NodeList students =
root.getElementsByTagName("学生");
students_Vector = new
Vector<Student>();
for (int i = 0; i < students.getLength(); i++)
{
// 一次取得每一个学生元素
Element ss = (Element) students.item(i);
// 创建一个学生的实例
Student stu = new
Student();
stu.setSex(ss.getAttribute("性别"));
NodeList names = ss.getElementsByTagName("姓名");
Element e =
(Element) names.item(0);
Node t =
e.getFirstChild();
stu.setName(t.getNodeValue());
NodeList ages = ss.getElementsByTagName("年龄");
e = (Element)
ages.item(0);
t =
e.getFirstChild();
stu.setAge(Integer.parseInt(t.getNodeValue()));
students_Vector.add(stu);
}
}
// 将Document内容 写入XML字符串并返回
private String callWriteXmlString(Document
doc, String encoding) {
try {
Source source = new DOMSource(doc);
ByteArrayOutputStream
outStream = new ByteArrayOutputStream();
OutputStreamWriter write = new
OutputStreamWriter(outStream);
Result result = new
StreamResult(write);
Transformer xformer =
TransformerFactory.newInstance()
.newTransformer();
xformer.setOutputProperty(OutputKeys.ENCODING,
encoding);
xformer.transform(source, result);
return outStream.toString();
} catch (TransformerConfigurationException e)
{
e.printStackTrace();
return null;
} catch
(TransformerException e) {
e.printStackTrace();
return
null;
}
}
/**
* 功能:生成XML格式的字符串
*/
public String writeXMLString()
{
DocumentBuilderFactory dbf =
DocumentBuilderFactory.newInstance();
DocumentBuilder builder =
null;
try {
builder = dbf.newDocumentBuilder();
} catch
(Exception e) {
}
Document doc = builder.newDocument();
Element root = doc.createElement("学生花名册");
doc.appendChild(root); //
将根元素添加到文档上
// 获取学生信息
for (Student s : students_Vector) {
//
创建一个学生
Element stu = doc.createElement("学生");
stu.setAttribute("性别",
s.getSex());
root.appendChild(stu);// 添加属性
// 创建文本姓名节点
Element name =
doc.createElement("姓名");
stu.appendChild(name);
Text tname =
doc.createTextNode(s.getName());
name.appendChild(tname);
// 创建文本年龄节点
Element age =
doc.createElement("年龄");
stu.appendChild(age); // 将age添加到学生节点上
Text
tage =
doc.createTextNode(String.valueOf(s.getAge()));
age.appendChild(tage); //
将文本节点放在age节点上
}
try {
String result = callWriteXmlString(doc,
"gb2312");
return result;
} catch (Exception e)
{
e.printStackTrace();
return null;
}
}
/**
* 主函数
*/
public static void main(String args[])
{
String str = "xml\\Student.xml";
DomTest t = new
DomTest();
System.out.println("解析原始XML文件:");
try
{
Vector<Student> v =
t.readXMLFile(str);
Iterator<Student> it = v.iterator();
while
(it.hasNext()) {
Student s = (Student)
it.next();
System.out.println(s.getName() + "\t" + s.getAge() +
"\t"
+ s.getSex());
}
} catch (Exception e)
{
e.printStackTrace();
}
String xmlStr =
t.writeXMLString();
System.out.println("\n生成的XML字符串:\n" + xmlStr);
try
{
Vector<Student> v =
t.readXMLString(xmlStr);
Iterator<Student> it =
v.iterator();
System.out.println("\n解析生成的XML字符串:");
while
(it.hasNext()) {
Student s = (Student)
it.next();
System.out.println(s.getName() + "\t" + s.getAge() +
"\t"
+ s.getSex());
}
} catch (Exception e)
{
e.printStackTrace();
}
}
}
class Student {
private String sex;
private String name;
private
int age;
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public void setSex(String s) {
sex = s;
}
public String getSex() {
return sex;
}
public void setName(String n) {
name = n;
}
public String getName() {
return name;
}
}
相关推荐
免费JAVA毕业设计 2024成品源码+论文+数据库+启动教程 启动教程:https://www.bilibili.com/video/BV1SzbFe7EGZ 项目讲解视频:https://www.bilibili.com/video/BV1Tb421n72S 二次开发教程:https://www.bilibili.com/video/BV18i421i7Dx
,IGBT结温估算 模型见另一个发布
"S7-200 PLC驱动的智能粮仓系统:带解释的接线图与组态画面原理详解",S7-200 mcgs基于plc的自动智能粮仓系统 带解释的梯形图接线图原理图图纸,io分配,组态画面 ,S7-200; PLC; 自动智能粮仓系统; 梯形图接线图; 原理图图纸; IO分配; 组态画面,基于S7-200 PLC的智能粮仓系统设计与实现
手机编程-1738391379497.jpg
,rk3399pro,rk3568,车载方案设计,4路AHD-1080P摄像头输入,防撞识别,助力车泥头车安全运输
,CAD、DXF导图,自动进行位置路径规划,源码可进行简单功能添加实现设备所需功能,已经在冲孔机,点胶机上应用,性价比超高。 打孔机实测一分钟1400个孔
,电机控制资料-- 注:本驱动器适合于直流有感无刷电机 功能特点 支持电压9V~36V,额定输出电流5A 支持电位器、开关、0~3.3V模拟信号范围、0 3.3 5 24V逻辑电平、PWM 频率 脉冲信号、RS485多种输入信号 支持占空比调速(调压)、速度闭环控制(稳速)、电流控制(稳流)多种调速方式 支持按键控制正反转速度,启停 特色功能 1. 霍尔自学习 电机的三相线和三霍尔信号线可不按顺序连接,驱动器可自动对电机霍尔顺序进行学习。 2. 稳速控制响应时间短 稳速控制时电机由正转2000RPM切为反转2000RPM,用时约1.0s,电机切过程平稳 3. 极低速稳速控制 电机进行极低速稳速控制,电机稳速控制均匀,无忽快忽慢现象。
《HFSS同轴馈电矩形微带天线的模型制作与参数优化:从结果中学习,使用HFSS软件包进行实践的详细教程》,HFSS同轴馈电矩形微带天线 天线模型,附带结果,可改参数,HFSS软件包 (有教程,具体到每一步,可以自己做出来) ,HFSS; 同轴馈电; 矩形微带天线; 可改参数; HFSS软件包; 附带结果; 教程,HFSS软件包:可改参微带天线模型附带结果教程
"基于第二篇文章求解方法,改进粒子群算法在微电网综合能源优化调度的应用与复现代码展示——第一篇模型的参考与实践",基于改进粒子群算法微电网综合能源优化调度 求解方法主要参考第二篇文章 模型参照第一篇 复现代码 ,核心关键词: 基于改进粒子群算法; 微电网综合能源优化调度; 求解方法; 第二篇文章; 模型; 第一篇文章; 复现代码;,基于第二篇求解方法的改进粒子群算法在微电网综合能源优化调度中的应用研究
基于Comsol模拟的三层顶板随机裂隙浆液扩散模型:考虑重力影响的瞬态扩散规律分析,Comsol模拟,考虑三层顶板包含随机裂隙的浆液扩散模型,考虑浆液重力的影响,模型采用的DFN插件建立随机裂隙,采用达西定律模块中的储水模型为控制方程,分析不同注浆压力条件下的浆液扩散规律,建立瞬态模型 ,Comsol模拟; 随机裂隙浆液扩散模型; 浆液重力影响; DFN插件; 达西定律模块储水模型; 注浆压力条件; 浆液扩散规律; 瞬态模型,Comsol浆液扩散模型:随机裂隙下考虑重力的瞬态扩散分析
"基于S7-200 PLC与MCGS组态的五层电梯控制系统设计与实现:带详细接线图、IO分配及组态画面解析",S7-200 PLC和MCGS组态5层电梯五层电梯PLC控制系统 带解释的梯形图接线图原理图图纸,io分配,组态画面 ,核心关键词:S7-200 PLC; MCGS组态; 五层电梯; PLC控制系统; 梯形图接线图; IO分配; 组态画面。,S7-200 PLC与MCGS组态五层电梯控制系统原理图及梯形图解析
一、项目简介 本项目是一套基于springBoot+mybatis+maven+vue夕阳红公寓管理系统 包含:项目源码、数据库脚本等,该项目附带全部源码可作为毕设使用。 项目都经过严格调试,eclipse或者idea 确保可以运行! 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值 二、技术实现 jdk版本:1.8 及以上 ide工具:IDEA或者eclipse 数据库: mysql5.5及以上 后端:spring+springboot+mybatis+maven+mysql 前端: vue , css,js , elementui 三、系统功能 1、系统角色主要包括:管理员、用户 2、系统功能 主要功能包括: 用户登录注册 首页 个人中心 修改密码 个人信息 访客管理 公告信息管理 缴费管理 维修管理 行程轨迹管理 单页号类型管理 公告类型管理 维修类型管理 租客管理 轮播图管理 余额充值等功能 详见 https://flypeppa.blog.csdn.net/article/details/143117373
基于时空Transformer的端到端的视频注视目标检测.pdf
Online Retail.xlsx
,C#地磅称重无人值守管理软件。 软件实现功能: 1、身份证信息读取。 2、人证识别。 3、车牌识别(臻识摄像头、海康摄像头)。 4、LED显示屏文字输出。 5、称重仪数据。 6、二维码扫码。 7、语音播报。 8、红外对射功能。 9、道闸控制。
com.deepseek.chat.apk
基于pyqt5+OpenPose的太极拳姿态识别系统可视化界面python源码+数据集.zip,个人大三大作业设计项目、经导师指导并认可通过的高分设计项目,评审分99分,代码完整确保可以运行,小白也可以亲自搞定,主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的学习者,也可作为课程设计、期末大作业。 该压缩包是一个基于PyQt5和OpenPose技术的太极拳姿态识别系统的源代码和相关资源集合。系统能够实现对太极拳动作的实时姿态识别,并通过可视化界面展示出来,为学习和教学太极拳提供便利。 二、技术栈与组件 PyQt5:一个Python绑定的Qt库,用于创建图形用户界面(GUI)应用程序。它提供了丰富的组件和工具,可以方便地构建各种复杂界面,如按钮、文本框、图像视图等,同时也支持事件驱动编程,使得用户交互更加灵活。 OpenPose:一个来自卡内基梅隆大学(CMU)的开源库,主要用于人体、面部、手部以及脚部的关键点检测。它采用了深度学习的方法,能够在单张图片上实时估计多人的关节位置,对于运动分析、姿态识别等领域非常有用。
1、文件内容:pygtk2-devel-2.24.0-9.el7.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/pygtk2-devel-2.24.0-9.el7.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、安装指导:私信博主,全程指导安装
"金纳米超表面模型:几何相位控制下的涡旋光生成与FDTD仿真研究",几何相位 金属超表面模型 涡旋光生成 FDTD仿真 复现lunwen:2012年Nano Letters:Dispersionless Phase Discontinuities for Controlling Light Propagation lunwen介绍:金纳米结构超表面模型,金属材料矩形结构,通过旋转角度执行几何相位,构建异常折反射超表面模型,通过涡旋相位匹配几何相位,构建生产轨道角动量的涡旋光场超表面; 案例内容:主要包括金纳米柱的单元结构仿真、几何相位计算,涡旋光的螺旋相位计算代码,以及异常折反射的超表面模型和轨道角动量光束生成的超表面模型; 案例包括fdtd模型、fdtd建模脚本、Matlab相位计算代码和电场复现结果,以及一份word教程,异常折反射和涡旋光相位的构建代码可用于任意波段,具备可拓展性。 ,核心关键词: 1. 几何相位 2. 金属超表面模型 3. 涡旋光生成 4. FDTD仿真 5. 复现论文 6. 金纳米结构 7. 异常折反射超表面模型 8. 轨道角动量光束 9. 单元结构仿
comso三维声表面波诱导液滴行为研究:液滴拉伸断裂过程的可视化及分析,包含液滴最高坐标、底面接触面积、空气接触面积与能量项研究。,comso三维声表面波作用液滴,液滴拉伸断裂形成液滴,结果图包含液滴最高坐标,液滴与底面接触面积,与空气接触面积,以及能量项 ,关键词:comso三维声表面波;液滴拉伸断裂;最高坐标;接触面积(底面/空气);能量项;结果图。,声波作用下液滴断裂,图示液滴信息及能量项分析