1.POI结构与常用类
(1)POI介绍
Apache POI是Apache软件基金会的开源项目,POI提供API给Java程序对Microsoft Office格式档案读和写的功能。 .NET的开发人员则可以利用NPOI (POI for .NET) 来存取 Microsoft Office文档的功能。
(2)POI结构说明
包名称 说明
HSSF 提供读写Microsoft Excel XLS格式档案的功能。
XSSF 提供读写Microsoft Excel OOXML XLSX格式档案的功能。
HWPF 提供读写Microsoft Word DOC格式档案的功能。
HSLF 提供读写Microsoft PowerPoint格式档案的功能。
HDGF 提供读Microsoft Visio格式档案的功能。
HPBF 提供读Microsoft Publisher格式档案的功能。
HSMF 提供读Microsoft Outlook格式档案的功能。
(3)POI常用类说明
类名 说明
HSSFWorkbook Excel的文档对象
HSSFSheet Excel的表单
HSSFRow Excel的行
HSSFCell Excel的格子单元
HSSFFont Excel字体
HSSFDataFormat 格子单元的日期格式
HSSFHeader Excel文档Sheet的页眉
HSSFFooter Excel文档Sheet的页脚
HSSFCellStyle 格子单元样式
HSSFDateUtil 日期
HSSFPrintSetup 打印
HSSFErrorConstants 错误信息表
回到顶部
2.Excel的基本操作
(1)创建Workbook和Sheet

publicclassTest00
{
publicstaticvoid main(String[] args)throwsIOException
{
String filePath=“d:\users\lizw\桌面\POI\sample.xls”;//文件路径
HSSFWorkbook workbook =newHSSFWorkbook();//创建Excel文件(Workbook)
HSSFSheet sheet = workbook.createSheet();//创建工作表(Sheet)
sheet = workbook.createSheet(“Test”);//创建工作表(Sheet)
FileOutputStream out =newFileOutputStream(filePath);
workbook.write(out);//保存Excel文件
out.close();//关闭文件流
System.out.println(“OK!”);
}
}
(2)创建单元格

HSSFSheet sheet = workbook.createSheet(“Test”);// 创建工作表(Sheet)
HSSFRow row = sheet.createRow(0);// 创建行,从0开始
HSSFCell cell = row.createCell(0);// 创建行的单元格,也是从0开始
cell.setCellValue(“李志伟”);// 设置单元格内容
row.createCell(1).setCellValue(false);// 设置单元格内容,重载
row.createCell(2).setCellValue(newDate());// 设置单元格内容,重载
row.createCell(3).setCellValue(12.345);// 设置单元格内容,重载

(3)创建文档摘要信息

workbook.createInformationProperties();//创建文档信息
DocumentSummaryInformation dsi= workbook.getDocumentSummaryInformation();//摘要信息
dsi.setCategory(“类别:Excel文件”);//类别
dsi.setManager(“管理者:李志伟”);//管理者
dsi.setCompany(“公司:–”);//公司
SummaryInformation si = workbook.getSummaryInformation();//摘要信息
si.setSubject(“主题:–”);//主题
si.setTitle(“标题:测试文档”);//标题
si.setAuthor(“作者:李志伟”);//作者
si.setComments(“备注:POI测试文档”);//备注

(4)创建批注

HSSFSheet sheet = workbook.createSheet(“Test”);// 创建工作表(Sheet)
HSSFPatriarch patr = sheet.createDrawingPatriarch();
HSSFClientAnchor anchor = patr.createAnchor(0,0,0,0,5,1,8,3);//创建批注位置
HSSFComment comment = patr.createCellComment(anchor);//创建批注
comment.setString(newHSSFRichTextString(“这是一个批注段落!”));//设置批注内容
comment.setAuthor(“李志伟”);//设置批注作者
comment.setVisible(true);//设置批注默认显示
HSSFCell cell = sheet.createRow(2).createCell(1);
cell.setCellValue(“测试”);
cell.setCellComment(comment);//把批注赋值给单元格

创建批注位置HSSFPatriarch.createAnchor(dx1, dy1, dx2, dy2, col1, row1, col2, row2)方法参数说明:

dx1 第1个单元格中x轴的偏移量
dy1 第1个单元格中y轴的偏移量
dx2 第2个单元格中x轴的偏移量
dy2 第2个单元格中y轴的偏移量
col1 第1个单元格的列号
row1 第1个单元格的行号
col2 第2个单元格的列号
row2 第2个单元格的行号
(5)创建页眉和页脚

HSSFSheet sheet = workbook.createSheet(“Test”);// 创建工作表(Sheet)
HSSFHeader header =sheet.getHeader();//得到页眉
header.setLeft(“页眉左边”);
header.setRight(“页眉右边”);
header.setCenter(“页眉中间”);
HSSFFooter footer =sheet.getFooter();//得到页脚
footer.setLeft(“页脚左边”);
footer.setRight(“页脚右边”);
footer.setCenter(“页脚中间”);

也可以使用Office自带的标签定义,你可以通过HSSFHeader或HSSFFooter访问到它们,都是静态属性,列表如下:

HSSFHeader.tab &A 表名
HSSFHeader.file &F 文件名
HSSFHeader.startBold &B 粗体开始
HSSFHeader.endBold &B 粗体结束
HSSFHeader.startUnderline &U 下划线开始
HSSFHeader.endUnderline &U 下划线结束
HSSFHeader.startDoubleUnderline &E 双下划线开始
HSSFHeader.endDoubleUnderline &E 双下划线结束
HSSFHeader.time &T 时间
HSSFHeader.date &D 日期
HSSFHeader.numPages &N 总页面数
HSSFHeader.page &P 当前页号
回到顶部
3.Excel的单元格操作
(1)设置格式

HSSFSheet sheet = workbook.createSheet(“Test”);// 创建工作表(Sheet)
HSSFRow row=sheet.createRow(0);
//设置日期格式–使用Excel内嵌的格式
HSSFCell cell=row.createCell(0);
cell.setCellValue(newDate());
HSSFCellStyle style=workbook.createCellStyle();
style.setDataFormat(HSSFDataFormat.getBuiltinFormat(“m/d/yy h:mm”));
cell.setCellStyle(style);
//设置保留2位小数–使用Excel内嵌的格式
cell=row.createCell(1);
cell.setCellValue(12.3456789);
style=workbook.createCellStyle();
style.setDataFormat(HSSFDataFormat.getBuiltinFormat(“0.00”));
cell.setCellStyle(style);
//设置货币格式–使用自定义的格式
cell=row.createCell(2);
cell.setCellValue(12345.6789);
style=workbook.createCellStyle();
style.setDataFormat(workbook.createDataFormat().getFormat(“¥#,##0”));
cell.setCellStyle(style);
//设置百分比格式–使用自定义的格式
cell=row.createCell(3);
cell.setCellValue(0.123456789);
style=workbook.createCellStyle();
style.setDataFormat(workbook.createDataFormat().getFormat(“0.00%”));
cell.setCellStyle(style);
//设置中文大写格式–使用自定义的格式
cell=row.createCell(4);
cell.setCellValue(12345);
style=workbook.createCellStyle();
style.setDataFormat(workbook.createDataFormat().getFormat("[DbNum2][$-804]0"));
cell.setCellStyle(style);
//设置科学计数法格式–使用自定义的格式
cell=row.createCell(5);
cell.setCellValue(12345);
style=workbook.createCellStyle();
style.setDataFormat(workbook.createDataFormat().getFormat(“0.00E+00”));
cell.setCellStyle(style);

HSSFDataFormat.getFormat和HSSFDataFormat.getBuiltinFormat的区别:当使用Excel内嵌的(或者说预定义)的格式时,直接用HSSFDataFormat.getBuiltinFormat静态方法即可。当使用自己定义的格式时,必须先调用HSSFWorkbook.createDataFormat(),因为这时在底层会先找有没有匹配的内嵌FormatRecord,如果没有就会新建一个FormatRecord,所以必须先调用这个方法,然后你就可以用获得的HSSFDataFormat实例的getFormat方法了,当然相对而言这种方式比较麻烦,所以内嵌格式还是用HSSFDataFormat.getBuiltinFormat静态方法更加直接一些。

(2)合并单元格

HSSFSheet sheet = workbook.createSheet(“Test”);// 创建工作表(Sheet)
HSSFRow row=sheet.createRow(0);
//合并列
HSSFCell cell=row.createCell(0);
cell.setCellValue(“合并列”);
CellRangeAddress region=newCellRangeAddress(0,0,0,5);
sheet.addMergedRegion(region);
//合并行
cell=row.createCell(6);
cell.setCellValue(“合并行”);
region=newCellRangeAddress(0,5,6,6);
sheet.addMergedRegion(region);

CellRangeAddress对象其实就是表示一个区域,其构造方法如下:CellRangeAddress(firstRow, lastRow, firstCol, lastCol),参数的说明:

firstRow 区域中第一个单元格的行号
lastRow 区域中最后一个单元格的行号
firstCol 区域中第一个单元格的列号
lastCol 区域中最后一个单元格的列号
提示:即使你没有用CreateRow和CreateCell创建过行或单元格,也完全可以直接创建区域然后把这一区域合并,Excel的区域合并信息是单独存储的,和RowRecord、ColumnInfoRecord不存在直接关系。
(3)单元格对齐

HSSFCell cell=row.createCell(0);
cell.setCellValue(“单元格对齐”);
HSSFCellStyle style=workbook.createCellStyle();
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);//水平居中
style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);//垂直居中
style.setWrapText(true);//自动换行
style.setIndention((short)5);//缩进
style.setRotation((short)60);//文本旋转,这里的取值是从-90到90,而不是0-180度。
cell.setCellStyle(style);

水平对齐相关参数

如果是左侧对齐就是HSSFCellStyle.ALIGN_FILL;
如果是居中对齐就是HSSFCellStyle.ALIGN_CENTER;
如果是右侧对齐就是HSSFCellStyle.ALIGN_RIGHT;
如果是跨列举中就是HSSFCellStyle.ALIGN_CENTER_SELECTION;
如果是两端对齐就是HSSFCellStyle.ALIGN_JUSTIFY;
如果是填充就是HSSFCellStyle.ALIGN_FILL;
垂直对齐相关参数

如果是靠上就是HSSFCellStyle.VERTICAL_TOP;
如果是居中就是HSSFCellStyle.VERTICAL_CENTER;
如果是靠下就是HSSFCellStyle.VERTICAL_BOTTOM;
如果是两端对齐就是HSSFCellStyle.VERTICAL_JUSTIFY;
(4)使用边框
边框和其他单元格设置一样也是调用CellStyle接口,CellStyle有2种和边框相关的属性,分别是:
边框相关属性

说明

范例

Border+方向

边框类型

BorderLeft, BorderRight等

方向+BorderColor

边框颜色

TopBorderColor,BottomBorderColor等

HSSFCell cell=row.createCell(1);
cell.setCellValue(“设置边框”);
HSSFCellStyle style=workbook.createCellStyle();
style.setBorderTop(HSSFCellStyle.BORDER_DOTTED);//上边框
style.setBorderBottom(HSSFCellStyle.BORDER_THICK);//下边框
style.setBorderLeft(HSSFCellStyle.BORDER_DOUBLE);//左边框
style.setBorderRight(HSSFCellStyle.BORDER_SLANTED_DASH_DOT);//右边框
style.setTopBorderColor(HSSFColor.RED.index);//上边框颜色
style.setBottomBorderColor(HSSFColor.BLUE.index);//下边框颜色
style.setLeftBorderColor(HSSFColor.GREEN.index);//左边框颜色
style.setRightBorderColor(HSSFColor.PINK.index);//右边框颜色
cell.setCellStyle(style);

其中边框类型分为以下几种:

边框范例图

对应的静态值

1

HSSFCellStyle.BORDER_DOTTED

2

HSSFCellStyle.BORDER_HAIR

3

HSSFCellStyle.BORDER_DASH_DOT_DOT

4

HSSFCellStyle.BORDER_DASH_DOT

5

HSSFCellStyle.BORDER_DASHED

6

HSSFCellStyle.BORDER_THIN

7

HSSFCellStyle.BORDER_MEDIUM_DASH_DOT_DOT

8

HSSFCellStyle.BORDER_SLANTED_DASH_DOT

9

HSSFCellStyle.BORDER_MEDIUM_DASH_DOT

10

HSSFCellStyle.BORDER_MEDIUM_DASHED

11

HSSFCellStyle.BORDER_MEDIUM

12

HSSFCellStyle.BORDER_THICK

13

HSSFCellStyle.BORDER_DOUBLE

(5)设置字体

HSSFCell cell = row.createCell(1);
cell.setCellValue(“设置字体”);
HSSFCellStyle style = workbook.createCellStyle();
HSSFFont font = workbook.createFont();
font.setFontName(“华文行楷”);//设置字体名称
font.setFontHeightInPoints((short)28);//设置字号
font.setColor(HSSFColor.RED.index);//设置字体颜色
font.setUnderline(FontFormatting.U_SINGLE);//设置下划线
font.setTypeOffset(FontFormatting.SS_SUPER);//设置上标下标
font.setStrikeout(true);//设置删除线
style.setFont(font);
cell.setCellStyle(style);

下划线选项值:单下划线 FontFormatting.U_SINGLE双下划线 FontFormatting.U_DOUBLE会计用单下划线 FontFormatting.U_SINGLE_ACCOUNTING会计用双下划线 FontFormatting.U_DOUBLE_ACCOUNTING

无下划线 FontFormatting.U_NONE
上标下标选项值:
上标 FontFormatting.SS_SUPER
下标 FontFormatting.SS_SUB
普通,默认值 FontFormatting.SS_NONE
(6)背景和纹理

HSSFCellStyle style = workbook.createCellStyle();
style.setFillForegroundColor(HSSFColor.GREEN.index);//设置图案颜色
style.setFillBackgroundColor(HSSFColor.RED.index);//设置图案背景色
style.setFillPattern(HSSFCellStyle.SQUARES);//设置图案样式
cell.setCellStyle(style);

图案样式及其对应的值:

图案样式

常量

1

HSSFCellStyle.NO_FILL

2

HSSFCellStyle.ALT_BARS

3

HSSFCellStyle.FINE_DOTS

4

HSSFCellStyle.SPARSE_DOTS

5

HSSFCellStyle.LESS_DOTS

6

HSSFCellStyle.LEAST_DOTS

7

HSSFCellStyle.BRICKS

8

HSSFCellStyle.BIG_SPOTS

9

HSSFCellStyle.THICK_FORWARD_DIAG

10

HSSFCellStyle.THICK_BACKWARD_DIAG

11

HSSFCellStyle.THICK_VERT_BANDS

12

HSSFCellStyle.THICK_HORZ_BANDS

13

HSSFCellStyle.THIN_HORZ_BANDS

14

HSSFCellStyle.THIN_VERT_BANDS

15

HSSFCellStyle.THIN_BACKWARD_DIAG

16

HSSFCellStyle.THIN_FORWARD_DIAG

17

HSSFCellStyle.SQUARES

18

HSSFCellStyle.DIAMONDS

(7)设置宽度和高度

HSSFSheet sheet = workbook.createSheet(“Test”);// 创建工作表(Sheet)
HSSFRow row = sheet.createRow(1);
HSSFCell cell = row.createCell(1);
cell.setCellValue(“123456789012345678901234567890”);
sheet.setColumnWidth(1,31*256);//设置第一列的宽度是31个字符宽度
row.setHeightInPoints(50);//设置行的高度是50个点

这里你会发现一个有趣的现象,setColumnWidth的第二个参数要乘以256,这是怎么回事呢?其实,这个参数的单位是1/256个字符宽度,也就是说,这里是把B列的宽度设置为了31个字符。
设置行高使用HSSFRow对象的setHeight和setHeightInPoints方法,这两个方法的区别在于setHeightInPoints的单位是点,而setHeight的单位是1/20个点,所以setHeight的值永远是setHeightInPoints的20倍。
你也可以使用HSSFSheet.setDefaultColumnWidth、HSSFSheet.setDefaultRowHeight和HSSFSheet.setDefaultRowHeightInPoints方法设置默认的列宽或行高。

(8)判断单元格是否为日期
判断单元格是否为日期类型,使用DateUtil.isCellDateFormatted(cell)方法,例如:

HSSFCell cell = row.createCell(1);
cell.setCellValue(newDate());//设置日期数据
System.out.println(DateUtil.isCellDateFormatted(cell));//输出:false
HSSFCellStyle style =workbook.createCellStyle();
style.setDataFormat(HSSFDataFormat.getBuiltinFormat(“m/d/yy h:mm”));
cell.setCellStyle(style);//设置日期样式
System.out.println(DateUtil.isCellDateFormatted(cell));//输出:true
回到顶部
4.使用Excel公式
(1)基本计算

HSSFSheet sheet = workbook.createSheet(“Test”);// 创建工作表(Sheet)
HSSFRow row = sheet.createRow(0);
HSSFCell cell = row.createCell(0);
cell.setCellFormula(“2+34");//设置公式
cell = row.createCell(1);
cell.setCellValue(10);
cell = row.createCell(2);
cell.setCellFormula("A1
B1”);//设置公式

(2)SUM函数

HSSFSheet sheet = workbook.createSheet(“Test”);// 创建工作表(Sheet)
HSSFRow row = sheet.createRow(0);
row.createCell(0).setCellValue(1);
row.createCell(1).setCellValue(2);
row.createCell(2).setCellValue(3);
row.createCell(3).setCellValue(4);
row.createCell(4).setCellValue(5);
row = sheet.createRow(1);
row.createCell(0).setCellFormula(“sum(A1,C1)”);//等价于"A1+C1"
row.createCell(1).setCellFormula(“sum(B1:D1)”);//等价于"B1+C1+D1"

(3)日期函数

HSSFSheet sheet = workbook.createSheet(“Test”);// 创建工作表(Sheet)
HSSFCellStyle style=workbook.createCellStyle();
style.setDataFormat(workbook.createDataFormat().getFormat(“yyyy-mm-dd”));
HSSFRow row = sheet.createRow(0);
Calendar date=Calendar.getInstance();//日历对象
HSSFCell cell=row.createCell(0);
date.set(2011,2,7);
cell.setCellValue(date.getTime());
cell.setCellStyle(style);//第一个单元格开始时间设置完成
cell=row.createCell(1);
date.set(2014,4,25);
cell.setCellValue(date.getTime());
cell.setCellStyle(style);//第一个单元格结束时间设置完成
cell=row.createCell(3);
cell.setCellFormula(“CONCATENATE(DATEDIF(A1,B1,“y”),“年”)”);
cell=row.createCell(4);
cell.setCellFormula(“CONCATENATE(DATEDIF(A1,B1,“m”),“月”)”);
cell=row.createCell(5);
cell.setCellFormula(“CONCATENATE(DATEDIF(A1,B1,“d”),“日”)”);

以上代码中的公式说明:DATEDIF(A1,B1,\"y\"):取得A1单元格的日期与B1单元格的日期的时间间隔。(“y”:表示以年为单位,”m”表示以月为单位;”d”表示以天为单位)。CONCATENATE(str1,str2,…):连接字符串。更多Excel的日期函数可参考:http://tonyqus.sinaapp.com/archives/286

(4)字符串相关函数

HSSFSheet sheet = workbook.createSheet(“Test”);// 创建工作表(Sheet)
HSSFRow row = sheet.createRow(0);
row.createCell(0).setCellValue(“abcdefg”);
row.createCell(1).setCellValue(“aa bb cc dd ee fF GG”);
row.createCell(3).setCellFormula(“UPPER(A1)”);
row.createCell(4).setCellFormula(“PROPER(B1)”);

以上代码中的公式说明:UPPER(String):将文本转换成大写形式。PROPER(String):将文字串的首字母及任何非字母字符之后的首字母转换成大写。将其余的字母转换成小写。更多Excel的字符串函数可参考:http://tonyqus.sinaapp.com/archives/289

(5)IF函数

HSSFSheet sheet = workbook.createSheet(“Test”);// 创建工作表(Sheet)
HSSFRow row = sheet.createRow(0);
row.createCell(0).setCellValue(12);
row.createCell(1).setCellValue(23);
row.createCell(3).setCellFormula(“IF(A1>B1,“A1大于B1”,“A1小于等于B1”)”);

以上代码中的公式说明:IF(logical_test,value_if_true,value_if_false)用来用作逻辑判断。其中Logical_test表示计算结果为 TRUE 或 FALSE 的任意值或表达式 ; value_if_true表示当表达式Logical_test的值为TRUE时的返回值;value_if_false表示当表达式Logical_test的值为FALSE时的返回值。

(6)CountIf和SumIf函数

HSSFSheet sheet = workbook.createSheet(“Test”);// 创建工作表(Sheet)
HSSFRow row = sheet.createRow(0);
row.createCell(0).setCellValue(57);
row.createCell(1).setCellValue(89);
row.createCell(2).setCellValue(56);
row.createCell(3).setCellValue(67);
row.createCell(4).setCellValue(60);
row.createCell(5).setCellValue(73);
row.createCell(7).setCellFormula(“COUNTIF(A1:F1,”>=60")");
row.createCell(8).setCellFormula(“SUMIF(A1:F1,”>=60",A1:F1)");

以上代码中的公式说明:COUNTIF(range,criteria):满足某条件的计数的函数。参数range:需要进行读数的计数;参数criteria:条件表达式,只有当满足此条件时才进行计数。SumIF(criteria_range, criteria,sum_range):用于统计某区域内满足某条件的值的求和。参数criteria_range:条件测试区域,第二个参数Criteria中的条件将与此区域中的值进行比较;参数criteria:条件测试值,满足条件的对应的sum_range项将进行求和计算;参数sum_range:汇总数据所在区域,求和时会排除掉不满足Criteria条件的对应的项。

(7)Lookup函数

HSSFSheet sheet = workbook.createSheet(“Test”);// 创建工作表(Sheet)
HSSFRow row = sheet.createRow(0);
row.createCell(0).setCellValue(0);
row.createCell(1).setCellValue(59);
row.createCell(2).setCellValue(“不及格”);
row = sheet.createRow(1);
row.createCell(0).setCellValue(60);
row.createCell(1).setCellValue(69);
row.createCell(2).setCellValue(“及格”);
row = sheet.createRow(2);
row.createCell(0).setCellValue(70);
row.createCell(1).setCellValue(79);
row.createCell(2).setCellValue(“良好”);
row = sheet.createRow(3);
row.createCell(0).setCellValue(80);
row.createCell(1).setCellValue(100);
row.createCell(2).setCellValue(“优秀”);
row = sheet.createRow(4);
row.createCell(0).setCellValue(75);
row.createCell(1).setCellFormula(“LOOKUP(A5,$A1:1:1:A4,4,4,C1:1:1:C4)");row.createCell(2).setCellFormula("VLOOKUP(A5,4)"); row.createCell(2).setCellFormula("VLOOKUP(A5,4)");row.createCell(2).setCellFormula("VLOOKUP(A5,A1:1:1:C$4,3,true)”);

以上代码中的公式说明:LOOKUP(lookup_value,lookup_vector,result_vector),第一个参数:需要查找的内容,本例中指向A5单元格,也就是75;第二个参数:比较对象区域,本例中的成绩需要与$A$1:$A$4中的各单元格中的值进行比较;第三个参数:查找结果区域,如果匹配到会将此区域中对应的数据返回。如本例中返回$C$1:$C$4中对应的值。

可能有人会问,字典中没有75对应的成绩啊,那么Excel中怎么匹配的呢?答案是模糊匹配,并且LOOKUP函数只支持模糊匹配。Excel会在$A1:1:1:A4中找小于75的最大值,也就是A3对应的70,然后将对应的4中找小于75的最大值,也就是A3对应的70,然后将对应的4中找小于75的最大值,也就是A3对应的70,然后将对应的C1:1:1:C4区域中的C3中的值返回,这就是最终结果“良好”的由来。VLOOKUP(lookupvalue,lookuparea,resultcol,isfuzzy),第一个参数:需要查找的内容,这里是A5单元格;第二个参数:需要比较的表,这里是4区域中的C3中的值返回,这就是最终结果“良好”的由来。 VLOOKUP(lookup_value,lookup_area,result_col,is_fuzzy ),第一个参数:需要查找的内容,这里是A5单元格;第二个参数:需要比较的表,这里是4区域中的C3中的值返回,这就是最终结果“良好”的由来。VLOOKUP(lookupv​alue,lookupa​rea,resultc​ol,isf​uzzy),第一个参数:需要查找的内容,这里是A5单元格;第二个参数:需要比较的表,这里是A1:1:1:C$4,注意VLOOKUP匹配时只与表中的第一列进行匹配。第三个参数:匹配结果对应的列序号。这里要对应的是成绩列,所以为3。第四个参数:指明是否模糊匹配。例子中的TRUE表示模糊匹配,与上例中一样。匹配到的是第三行。如果将此参数改为FALSE,因为在表中的第1列中找不到75,所以会报“#N/A”的计算错误。
另外,还有与VLOKUP类似的HLOOKUP。不同的是VLOOKUP用于在表格或数值数组的首列查找指定的数值,并由此返回表格或数组当前行中指定列处的数值。而HLOOKUP用于在表格或数值数组的首行查找指定的数值,并由此返回表格或数组当前列中指定行处的数值。读者可以自已去尝试。
(8)随机数函数

HSSFSheet sheet = workbook.createSheet(“Test”);// 创建工作表(Sheet)
HSSFRow row = sheet.createRow(0);
row.createCell(0).setCellFormula(“RAND()”);//取0-1之间的随机数
row.createCell(1).setCellFormula(“int(RAND()*100)”);//取0-100之间的随机整数
row.createCell(2).setCellFormula(“rand()*10+10”);//取10-20之间的随机实数
row.createCell(3).setCellFormula(“CHAR(INT(RAND()*26)+97)”);//随机小写字母
row.createCell(4).setCellFormula(“CHAR(INT(RAND()*26)+65)”);//随机大写字母
//随机大小写字母
row.createCell(5).setCellFormula(“CHAR(INT(RAND()*26)+if(INT(RAND()*2)=0,97,65))”);

以上代码中的公式说明:上面几例中除了用到RAND函数以外,还用到了CHAR函数用来将ASCII码换为字母,INT函数用来取整。值得注意的是INT函数不会四舍五入,无论小数点后是多少都会被舍去。

(9)获得公式的返回值

HSSFSheet sheet = workbook.createSheet(“Test”);// 创建工作表(Sheet)
HSSFRow row = sheet.createRow(0);
row.createCell(0).setCellValue(7);//A1
row.createCell(1).setCellValue(8);//B1
HSSFCell cell=row.createCell(2);
cell.setCellFormula(“A1*B1+14”);
HSSFFormulaEvaluator e =newHSSFFormulaEvaluator(workbook);
cell = e.evaluateInCell(cell);//若Excel文件不是POI创建的,则不必调用此方法
System.out.println(“公式计算结果:”+cell.getNumericCellValue());

回到顶部
5.使用图形
(1)画线

HSSFSheet sheet = workbook.createSheet(“Test”);// 创建工作表(Sheet)
HSSFPatriarch patriarch=sheet.createDrawingPatriarch();
HSSFClientAnchor anchor =newHSSFClientAnchor(0,0,0,0,(short)1,0,(short)4,4);
HSSFSimpleShape line = patriarch.createSimpleShape(anchor);
line.setShapeType(HSSFSimpleShape.OBJECT_TYPE_LINE);//设置图形类型
line.setLineStyle(HSSFShape.LINESTYLE_SOLID);//设置图形样式
line.setLineWidth(6350);//在POI中线的宽度12700表示1pt,所以这里是0.5pt粗的线条。

通常,利用POI画图主要有以下几个步骤:1. 创建一个Patriarch(注意,一个sheet中通常只创建一个Patriarch对象);2. 创建一个Anchor,以确定图形的位置;3. 调用Patriarch创建图形;4. 设置图形类型(直线,矩形,圆形等)及样式(颜色,粗细等)。
关于HSSFClientAnchor(dx1,dy1,dx2,dy2,col1,row1,col2,row2)的参数,有必要在这里说明一下:dx1:起始单元格的x偏移量,如例子中的0表示直线起始位置距B1单元格左侧的距离;dy1:起始单元格的y偏移量,如例子中的0表示直线起始位置距B1单元格上侧的距离;dx2:终止单元格的x偏移量,如例子中的0表示直线起始位置距E5单元格左侧的距离;dy2:终止单元格的y偏移量,如例子中的0表示直线起始位置距E5单元格上侧的距离;col1:起始单元格列序号,从0开始计算;row1:起始单元格行序号,从0开始计算,如例子中col1=1,row1=0就表示起始单元格为B1;col2:终止单元格列序号,从0开始计算;row2:终止单元格行序号,从0开始计算,如例子中col2=4,row2=4就表示起始单元格为E5;
最后,关于LineStyle属性,有如下一些可选值,对应的效果分别如图所示:

(2)画矩形

HSSFSheet sheet = workbook.createSheet(“Test”);// 创建工作表(Sheet)
HSSFPatriarch patriarch=sheet.createDrawingPatriarch();
HSSFClientAnchor anchor =newHSSFClientAnchor(255,122,255,122,(short)1,0,(short)4,3);
HSSFSimpleShape rec = patriarch.createSimpleShape(anchor);
rec.setShapeType(HSSFSimpleShape.OBJECT_TYPE_RECTANGLE);
rec.setLineStyle(HSSFShape.LINESTYLE_DASHGEL);//设置边框样式
rec.setFillColor(255,0,0);//设置填充色
rec.setLineWidth(25400);//设置边框宽度
rec.setLineStyleColor(0,0,255);//设置边框颜色

(3)画圆形
更改上例的代码如下:
rec.setShapeType(HSSFSimpleShape.OBJECT_TYPE_OVAL);//设置图片类型

(4)画Grid
在POI中,本身没有画Grid(网格)的方法。但我们知道Grid其实就是由横线和竖线构成的,所在我们可以通过画线的方式来模拟画Grid。代码如下:

HSSFSheet sheet = workbook.createSheet(“Test”);// 创建工作表(Sheet)
HSSFRow row = sheet.createRow(2);
row.createCell(1);
row.setHeightInPoints(240);
sheet.setColumnWidth(2,9000);
int linesCount =20;
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
//因为HSSFClientAnchor中dx只能在0-1023之间,dy只能在0-255之间,这里采用比例的方式
double xRatio =1023.0/(linesCount *10);
double yRatio =255.0/(linesCount *10);
// 画竖线
int x1 =0;
int y1 =0;
int x2 =0;
int y2 =200;
for(int i =0; i < linesCount; i++)
{
HSSFClientAnchor a2 =newHSSFClientAnchor();
a2.setAnchor((short)2,2,(int)(x1 * xRatio),
(int)(y1 * yRatio),(short)2,2,(int)(x2 * xRatio),
(int)(y2 * yRatio));
HSSFSimpleShape shape2 = patriarch.createSimpleShape(a2);
shape2.setShapeType(HSSFSimpleShape.OBJECT_TYPE_LINE);
x1 +=10;
x2 +=10;
}
// 画横线
x1 =0;
y1 =0;
x2 =200;
y2 =0;
for(int i =0; i < linesCount; i++)
{
HSSFClientAnchor a2 =newHSSFClientAnchor();
a2.setAnchor((short)2,2,(int)(x1 * xRatio),
(int)(y1 * yRatio),(short)2,2,(int)(x2 * xRatio),
(int)(y2 * yRatio));
HSSFSimpleShape shape2 = patriarch.createSimpleShape(a2);
shape2.setShapeType(HSSFSimpleShape.OBJECT_TYPE_LINE);
y1 +=10;
y2 +=10;
}

(5)插入图片

HSSFSheet sheet = workbook.createSheet(“Test”);// 创建工作表(Sheet)
FileInputStream stream=newFileInputStream(“d:\POI\Apache.gif”);
byte[] bytes=newbyte[(int)stream.getChannel().size()];
stream.read(bytes);//读取图片到二进制数组
int pictureIdx = workbook.addPicture(bytes,HSSFWorkbook.PICTURE_TYPE_JPEG);
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
HSSFClientAnchor anchor =newHSSFClientAnchor(0,0,0,0,(short)0,0,(short)5,5);
HSSFPicture pict = patriarch.createPicture(anchor, pictureIdx);
//pict.resize();//自动调节图片大小,图片位置信息可能丢失

(6)从Excel文件提取图片

InputStream inp =newFileInputStream(filePath);
HSSFWorkbook workbook =newHSSFWorkbook(inp);//读取现有的Excel文件
List pictures = workbook.getAllPictures();
for(int i=0;i<pictures.size();i++)
{
HSSFPictureData pic=pictures.get(i);
String ext = pic.suggestFileExtension();
if(ext.equals(“png”))//判断文件格式
{
FileOutputStream png=newFileOutputStream(“d:\POI\Apache.png”);
png.write(pic.getData());
png.close();//保存图片
}
}
回到顶部
6.Excel表操作
(1)设置默认工作表

HSSFWorkbook workbook =newHSSFWorkbook();// 创建Excel文件(Workbook)
workbook.createSheet(“Test0”);// 创建工作表(Sheet)
workbook.createSheet(“Test1”);// 创建工作表(Sheet)
workbook.createSheet(“Test2”);// 创建工作表(Sheet)
workbook.createSheet(“Test3”);// 创建工作表(Sheet)
workbook.setActiveSheet(2);//设置默认工作表
(2)重命名工作表

HSSFWorkbook workbook =newHSSFWorkbook();// 创建Excel文件(Workbook)
workbook.createSheet(“Test0”);// 创建工作表(Sheet)
workbook.createSheet(“Test1”);// 创建工作表(Sheet)
workbook.createSheet(“Test2”);// 创建工作表(Sheet)
workbook.createSheet(“Test3”);// 创建工作表(Sheet)
workbook.setSheetName(2,“1234”);//重命名工作表
(3)调整表单显示比例

HSSFWorkbook workbook =newHSSFWorkbook();// 创建Excel文件(Workbook)
HSSFSheet sheet1= workbook.createSheet(“Test0”);// 创建工作表(Sheet)
HSSFSheet sheet2=workbook.createSheet(“Test1”);// 创建工作表(Sheet)
HSSFSheet sheet3=workbook.createSheet(“Test2”);// 创建工作表(Sheet)
sheet1.setZoom(1,2);//50%显示比例
sheet2.setZoom(2,1);//200%显示比例
sheet3.setZoom(1,10);//10%显示比例

(4)显示/隐藏网格线

HSSFWorkbook workbook =newHSSFWorkbook();// 创建Excel文件(Workbook)
HSSFSheet sheet1= workbook.createSheet(“Test0”);// 创建工作表(Sheet)
HSSFSheet sheet2=workbook.createSheet(“Test1”);// 创建工作表(Sheet)
sheet1.setDisplayGridlines(false);//隐藏Excel网格线,默认值为true
sheet2.setGridsPrinted(true);//打印时显示网格线,默认值为false

(5)遍历Sheet

String filePath =“d:\users\lizw\桌面\POI\sample.xls”;
FileInputStream stream =newFileInputStream(filePath);
HSSFWorkbook workbook =newHSSFWorkbook(stream);//读取现有的Excel
HSSFSheet sheet= workbook.getSheet(“Test0”);//得到指定名称的Sheet
for(Row row : sheet)
{
for(Cell cell : row)
{
System.out.print(cell +"\t");
}
System.out.println();
}

回到顶部
7.Excel行列操作
(1)组合行、列

HSSFSheet sheet= workbook.createSheet(“Test0”);// 创建工作表(Sheet)
sheet.groupRow(1,3);//组合行
sheet.groupRow(2,4);//组合行
sheet.groupColumn(2,7);//组合列

这里简单的介绍一下什么叫做组合:组合分为行组合和列组合,所谓行组合,就是让n行组合成一个集合,能够进行展开和合拢操作。
使用POI也可以取消组合,例如:sheet.ungroupColumn(1, 3);//取消列组合

(2)锁定列
在Excel中,有时可能会出现列数太多或是行数太多的情况,这时可以通过锁定列来冻结部分列,不随滚动条滑动,方便查看。

HSSFSheet sheet= workbook.createSheet(“Test0”);// 创建工作表(Sheet)
sheet.createFreezePane(2,3,15,25);//冻结行列

下面对CreateFreezePane的参数作一下说明:第一个参数表示要冻结的列数;第二个参数表示要冻结的行数,这里只冻结列所以为0;第三个参数表示右边区域可见的首列序号,从1开始计算;第四个参数表示下边区域可见的首行序号,也是从1开始计算,这里是冻结列,所以为0;

(3)上下移动行

FileInputStream stream =newFileInputStream(filePath);
HSSFWorkbook workbook =newHSSFWorkbook(stream);
HSSFSheet sheet = workbook.getSheet(“Test0”);
sheet.shiftRows(2,4,2);//把第3行到第4行向下移动两行

HSSFSheet.shiftRows(startRow, endRow, n)参数说明startRow:需要移动的起始行;endRow:需要移动的结束行;n:移动的位置,正数表示向下移动,负数表示向上移动;

回到顶部
8.Excel的其他功能
(1)设置密码

HSSFSheet sheet= workbook.createSheet(“Test0”);// 创建工作表(Sheet)
HSSFRow row=sheet.createRow(1);
HSSFCell cell=row.createCell(1);
cell.setCellValue(“已锁定”);
HSSFCellStyle locked = workbook.createCellStyle();
locked.setLocked(true);//设置锁定
cell.setCellStyle(locked);
cell=row.createCell(2);
cell.setCellValue(“未锁定”);
HSSFCellStyle unlocked = workbook.createCellStyle();
unlocked.setLocked(false);//设置不锁定
cell.setCellStyle(unlocked);
sheet.protectSheet(“password”);//设置保护密码

(2)数据有效性

HSSFSheet sheet= workbook.createSheet(“Test0”);// 创建工作表(Sheet)
HSSFRow row=sheet.createRow(0);
HSSFCell cell=row.createCell(0);
cell.setCellValue(“日期列”);
CellRangeAddressList regions =newCellRangeAddressList(1,65535,0,0);//选定一个区域
DVConstraint constraint =DVConstraint.createDateConstraint(
DVConstraint.OperatorType.BETWEEN,“1993-01-01”,“2014-12-31”,“yyyy-MM-dd”);
HSSFDataValidation dataValidate =newHSSFDataValidation(regions, constraint);
dataValidate.createErrorBox(“错误”,“你必须输入一个时间!”);
sheet.addValidationData(dataValidate);

CellRangeAddressList类表示一个区域,构造函数中的四个参数分别表示起始行序号,终止行序号,起始列序号,终止列序号。65535是一个Sheet的最大行数。另外,CreateDateConstraint的第一个参数除了设置成DVConstraint.OperatorType.BETWEEN外,还可以设置成如下一些值,大家可以自己一个个去试看看效果:验证的数据类型也有几种选择,如下:

(3)生成下拉式菜单

CellRangeAddressList regions =newCellRangeAddressList(0,65535,0,0);
DVConstraint constraint =DVConstraint.createExplicitListConstraint(newString[]{“C++”,“Java”,“C#”});
HSSFDataValidation dataValidate =newHSSFDataValidation(regions, constraint);
sheet.addValidationData(dataValidate);

(4)打印基本设置

HSSFSheet sheet= workbook.createSheet(“Test0”);// 创建工作表(Sheet)
HSSFPrintSetup print = sheet.getPrintSetup();//得到打印对象
print.setLandscape(false);//true,则表示页面方向为横向;否则为纵向
print.setScale((short)80);//缩放比例80%(设置为0-100之间的值)
print.setFitWidth((short)2);//设置页宽
print.setFitHeight((short)4);//设置页高
print.setPaperSize(HSSFPrintSetup.A4_PAPERSIZE);//纸张设置
print.setUsePage(true);//设置打印起始页码不使用"自动"
print.setPageStart((short)6);//设置打印起始页码
sheet.setPrintGridlines(true);//设置打印网格线
print.setNoColor(true);//值为true时,表示单色打印
print.setDraft(true);//值为true时,表示用草稿品质打印
print.setLeftToRight(true);//true表示“先行后列”;false表示“先列后行”
print.setNotes(true);//设置打印批注
sheet.setAutobreaks(false);//Sheet页自适应页面大小
更详细的打印设置请参考: http://tonyqus.sinaapp.com/archives/271
(5)超链接

HSSFSheet sheet = workbook.createSheet(“Test0”);
CreationHelper createHelper = workbook.getCreationHelper();
// 关联到网站
Hyperlink link = createHelper.createHyperlink(Hyperlink.LINK_URL);
link.setAddress(“http://poi.apache.org/”);
sheet.createRow(0).createCell(0).setHyperlink(link);
// 关联到当前目录的文件
link = createHelper.createHyperlink(Hyperlink.LINK_FILE);
link.setAddress(“sample.xls”);
sheet.createRow(0).createCell(1).setHyperlink(link);
// e-mail 关联
link = createHelper.createHyperlink(Hyperlink.LINK_EMAIL);
link.setAddress(“mailto:poi@apache.org?subject=Hyperlinks”);
sheet.createRow(0).createCell(2).setHyperlink(link);
//关联到工作簿中的位置
link = createHelper.createHyperlink(Hyperlink.LINK_DOCUMENT);
link.setAddress("‘Test0’!C3");//Sheet名为Test0的C3位置
sheet.createRow(0).createCell(3).setHyperlink(link);

回到顶部
9.POI对Word的基本操作
(1)POI操作Word简介
POI读写Excel功能强大、操作简单。但是POI操作时,一般只用它读取word文档,POI只能能够创建简单的word文档,相对而言POI操作时的功能太少。
(2)POI创建Word文档的简单示例

XWPFDocument doc =newXWPFDocument();// 创建Word文件
XWPFParagraph p = doc.createParagraph();// 新建一个段落
p.setAlignment(ParagraphAlignment.CENTER);// 设置段落的对齐方式
p.setBorderBottom(Borders.DOUBLE);//设置下边框
p.setBorderTop(Borders.DOUBLE);//设置上边框
p.setBorderRight(Borders.DOUBLE);//设置右边框
p.setBorderLeft(Borders.DOUBLE);//设置左边框
XWPFRun r = p.createRun();//创建段落文本
r.setText(“POI创建的Word段落文本”);
r.setBold(true);//设置为粗体
r.setColor(“FF0000”);//设置颜色
p = doc.createParagraph();// 新建一个段落
r = p.createRun();
r.setText(“POI读写Excel功能强大、操作简单。”);
XWPFTable table= doc.createTable(3,3);//创建一个表格
table.getRow(0).getCell(0).setText(“表格1”);
table.getRow(1).getCell(1).setText(“表格2”);
table.getRow(2).getCell(2).setText(“表格3”);
FileOutputStream out =newFileOutputStream(“d:\POI\sample.doc”);
doc.write(out);
out.close();

(3)POI读取Word文档里的文字

FileInputStream stream =newFileInputStream(“d:\POI\sample.doc”);
XWPFDocument doc =newXWPFDocument(stream);// 创建Word文件
for(XWPFParagraph p : doc.getParagraphs())//遍历段落
{
System.out.print(p.getParagraphText());
}
for(XWPFTable table : doc.getTables())//遍历表格
{
for(XWPFTableRow row : table.getRows())
{
for(XWPFTableCell cell : row.getTableCells())
{
System.out.print(cell.getText());
}
}
}


这里写自定义目录标题

  • 欢迎使用Markdown编辑器
    • 新的改变
    • 功能快捷键
    • 合理的创建标题,有助于目录的生成
    • 如何改变文本的样式
    • 插入链接与图片
    • 如何插入一段漂亮的代码片
    • 生成一个适合你的列表
    • 创建一个表格
      • 设定内容居中、居左、居右
      • SmartyPants
    • 创建一个自定义列表
    • 如何创建一个注脚
    • 注释也是必不可少的
    • KaTeX数学公式
    • 新的甘特图功能,丰富你的文章
    • UML 图表
    • FLowchart流程图
    • 导出与导入
      • 导出
      • 导入

欢迎使用Markdown编辑器

你好! 这是你第一次使用 Markdown编辑器 所展示的欢迎页。如果你想学习如何使用Markdown编辑器, 可以仔细阅读这篇文章,了解一下Markdown的基本语法知识。

新的改变

我们对Markdown编辑器进行了一些功能拓展与语法支持,除了标准的Markdown编辑器功能,我们增加了如下几点新功能,帮助你用它写博客:

  1. 全新的界面设计 ,将会带来全新的写作体验;
  2. 在创作中心设置你喜爱的代码高亮样式,Markdown 将代码片显示选择的高亮样式 进行展示;
  3. 增加了 图片拖拽 功能,你可以将本地的图片直接拖拽到编辑区域直接展示;
  4. 全新的 KaTeX数学公式 语法;
  5. 增加了支持甘特图的mermaid语法1 功能;
  6. 增加了 多屏幕编辑 Markdown文章功能;
  7. 增加了 焦点写作模式、预览模式、简洁写作模式、左右区域同步滚轮设置 等功能,功能按钮位于编辑区域与预览区域中间;
  8. 增加了 检查列表 功能。

功能快捷键

撤销:Ctrl/Command + Z
重做:Ctrl/Command + Y
加粗:Ctrl/Command + B
斜体:Ctrl/Command + I
标题:Ctrl/Command + Shift + H
无序列表:Ctrl/Command + Shift + U
有序列表:Ctrl/Command + Shift + O
检查列表:Ctrl/Command + Shift + C
插入代码:Ctrl/Command + Shift + K
插入链接:Ctrl/Command + Shift + L
插入图片:Ctrl/Command + Shift + G
查找:Ctrl/Command + F
替换:Ctrl/Command + G

合理的创建标题,有助于目录的生成

直接输入1次#,并按下space后,将生成1级标题。
输入2次#,并按下space后,将生成2级标题。
以此类推,我们支持6级标题。有助于使用TOC语法后生成一个完美的目录。

如何改变文本的样式

强调文本 强调文本

加粗文本 加粗文本

标记文本

删除文本

引用文本

H2O is是液体。

210 运算结果是 1024.

插入链接与图片

链接: link.

图片:

带尺寸的图片:

居中的图片:

居中并且带尺寸的图片:

当然,我们为了让用户更加便捷,我们增加了图片拖拽功能。

如何插入一段漂亮的代码片

去博客设置页面,选择一款你喜欢的代码片高亮样式,下面展示同样高亮的 代码片.

// An highlighted block
var foo = 'bar';

生成一个适合你的列表

  • 项目

    • 项目

      • 项目
  1. 项目1
  2. 项目2
  3. 项目3
  • 计划任务
  • 完成任务

创建一个表格

一个简单的表格是这么创建的:

项目 Value
电脑 $1600
手机 $12
导管 $1

设定内容居中、居左、居右

使用:---------:居中
使用:----------居左
使用----------:居右

第一列 第二列 第三列
第一列文本居中 第二列文本居右 第三列文本居左

SmartyPants

SmartyPants将ASCII标点字符转换为“智能”印刷标点HTML实体。例如:

TYPE ASCII HTML
Single backticks 'Isn't this fun?' ‘Isn’t this fun?’
Quotes "Isn't this fun?" “Isn’t this fun?”
Dashes -- is en-dash, --- is em-dash – is en-dash, — is em-dash

创建一个自定义列表

Markdown
Text-to-HTML conversion tool
Authors
John
Luke

如何创建一个注脚

一个具有注脚的文本。2

注释也是必不可少的

Markdown将文本转换为 HTML

KaTeX数学公式

您可以使用渲染LaTeX数学表达式 KaTeX:

Gamma公式展示 Γ(n)=(n−1)!∀n∈N\Gamma(n) = (n-1)!\quad\forall n\in\mathbb NΓ(n)=(n−1)!∀n∈N 是通过欧拉积分

Γ(z)=∫0∞tz−1e−tdt.\Gamma(z) = \int_0^\infty t^{z-1}e^{-t}dt\,. Γ(z)=∫0∞​tz−1e−tdt.

你可以找到更多关于的信息 LaTeX 数学表达式here.

新的甘特图功能,丰富你的文章

Mon 06Mon 13Mon 20已完成 进行中 计划一 计划二 现有任务Adding GANTT diagram functionality to mermaid
  • 关于 甘特图 语法,参考 这儿,

UML 图表

可以使用UML图表进行渲染。 Mermaid. 例如下面产生的一个序列图:

#mermaid-svg-9bC5cWBSHzIx8H9j .label{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);fill:#333;color:#333}#mermaid-svg-9bC5cWBSHzIx8H9j .label text{fill:#333}#mermaid-svg-9bC5cWBSHzIx8H9j .node rect,#mermaid-svg-9bC5cWBSHzIx8H9j .node circle,#mermaid-svg-9bC5cWBSHzIx8H9j .node ellipse,#mermaid-svg-9bC5cWBSHzIx8H9j .node polygon,#mermaid-svg-9bC5cWBSHzIx8H9j .node path{fill:#ECECFF;stroke:#9370db;stroke-width:1px}#mermaid-svg-9bC5cWBSHzIx8H9j .node .label{text-align:center;fill:#333}#mermaid-svg-9bC5cWBSHzIx8H9j .node.clickable{cursor:pointer}#mermaid-svg-9bC5cWBSHzIx8H9j .arrowheadPath{fill:#333}#mermaid-svg-9bC5cWBSHzIx8H9j .edgePath .path{stroke:#333;stroke-width:1.5px}#mermaid-svg-9bC5cWBSHzIx8H9j .flowchart-link{stroke:#333;fill:none}#mermaid-svg-9bC5cWBSHzIx8H9j .edgeLabel{background-color:#e8e8e8;text-align:center}#mermaid-svg-9bC5cWBSHzIx8H9j .edgeLabel rect{opacity:0.9}#mermaid-svg-9bC5cWBSHzIx8H9j .edgeLabel span{color:#333}#mermaid-svg-9bC5cWBSHzIx8H9j .cluster rect{fill:#ffffde;stroke:#aa3;stroke-width:1px}#mermaid-svg-9bC5cWBSHzIx8H9j .cluster text{fill:#333}#mermaid-svg-9bC5cWBSHzIx8H9j div.mermaidTooltip{position:absolute;text-align:center;max-width:200px;padding:2px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);font-size:12px;background:#ffffde;border:1px solid #aa3;border-radius:2px;pointer-events:none;z-index:100}#mermaid-svg-9bC5cWBSHzIx8H9j .actor{stroke:#ccf;fill:#ECECFF}#mermaid-svg-9bC5cWBSHzIx8H9j text.actor>tspan{fill:#000;stroke:none}#mermaid-svg-9bC5cWBSHzIx8H9j .actor-line{stroke:grey}#mermaid-svg-9bC5cWBSHzIx8H9j .messageLine0{stroke-width:1.5;stroke-dasharray:none;stroke:#333}#mermaid-svg-9bC5cWBSHzIx8H9j .messageLine1{stroke-width:1.5;stroke-dasharray:2, 2;stroke:#333}#mermaid-svg-9bC5cWBSHzIx8H9j #arrowhead path{fill:#333;stroke:#333}#mermaid-svg-9bC5cWBSHzIx8H9j .sequenceNumber{fill:#fff}#mermaid-svg-9bC5cWBSHzIx8H9j #sequencenumber{fill:#333}#mermaid-svg-9bC5cWBSHzIx8H9j #crosshead path{fill:#333;stroke:#333}#mermaid-svg-9bC5cWBSHzIx8H9j .messageText{fill:#333;stroke:#333}#mermaid-svg-9bC5cWBSHzIx8H9j .labelBox{stroke:#ccf;fill:#ECECFF}#mermaid-svg-9bC5cWBSHzIx8H9j .labelText,#mermaid-svg-9bC5cWBSHzIx8H9j .labelText>tspan{fill:#000;stroke:none}#mermaid-svg-9bC5cWBSHzIx8H9j .loopText,#mermaid-svg-9bC5cWBSHzIx8H9j .loopText>tspan{fill:#000;stroke:none}#mermaid-svg-9bC5cWBSHzIx8H9j .loopLine{stroke-width:2px;stroke-dasharray:2, 2;stroke:#ccf;fill:#ccf}#mermaid-svg-9bC5cWBSHzIx8H9j .note{stroke:#aa3;fill:#fff5ad}#mermaid-svg-9bC5cWBSHzIx8H9j .noteText,#mermaid-svg-9bC5cWBSHzIx8H9j .noteText>tspan{fill:#000;stroke:none}#mermaid-svg-9bC5cWBSHzIx8H9j .activation0{fill:#f4f4f4;stroke:#666}#mermaid-svg-9bC5cWBSHzIx8H9j .activation1{fill:#f4f4f4;stroke:#666}#mermaid-svg-9bC5cWBSHzIx8H9j .activation2{fill:#f4f4f4;stroke:#666}#mermaid-svg-9bC5cWBSHzIx8H9j .mermaid-main-font{font-family:"trebuchet ms", verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-9bC5cWBSHzIx8H9j .section{stroke:none;opacity:0.2}#mermaid-svg-9bC5cWBSHzIx8H9j .section0{fill:rgba(102,102,255,0.49)}#mermaid-svg-9bC5cWBSHzIx8H9j .section2{fill:#fff400}#mermaid-svg-9bC5cWBSHzIx8H9j .section1,#mermaid-svg-9bC5cWBSHzIx8H9j .section3{fill:#fff;opacity:0.2}#mermaid-svg-9bC5cWBSHzIx8H9j .sectionTitle0{fill:#333}#mermaid-svg-9bC5cWBSHzIx8H9j .sectionTitle1{fill:#333}#mermaid-svg-9bC5cWBSHzIx8H9j .sectionTitle2{fill:#333}#mermaid-svg-9bC5cWBSHzIx8H9j .sectionTitle3{fill:#333}#mermaid-svg-9bC5cWBSHzIx8H9j .sectionTitle{text-anchor:start;font-size:11px;text-height:14px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-9bC5cWBSHzIx8H9j .grid .tick{stroke:#d3d3d3;opacity:0.8;shape-rendering:crispEdges}#mermaid-svg-9bC5cWBSHzIx8H9j .grid .tick text{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-9bC5cWBSHzIx8H9j .grid path{stroke-width:0}#mermaid-svg-9bC5cWBSHzIx8H9j .today{fill:none;stroke:red;stroke-width:2px}#mermaid-svg-9bC5cWBSHzIx8H9j .task{stroke-width:2}#mermaid-svg-9bC5cWBSHzIx8H9j .taskText{text-anchor:middle;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-9bC5cWBSHzIx8H9j .taskText:not([font-size]){font-size:11px}#mermaid-svg-9bC5cWBSHzIx8H9j .taskTextOutsideRight{fill:#000;text-anchor:start;font-size:11px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-9bC5cWBSHzIx8H9j .taskTextOutsideLeft{fill:#000;text-anchor:end;font-size:11px}#mermaid-svg-9bC5cWBSHzIx8H9j .task.clickable{cursor:pointer}#mermaid-svg-9bC5cWBSHzIx8H9j .taskText.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-9bC5cWBSHzIx8H9j .taskTextOutsideLeft.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-9bC5cWBSHzIx8H9j .taskTextOutsideRight.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-9bC5cWBSHzIx8H9j .taskText0,#mermaid-svg-9bC5cWBSHzIx8H9j .taskText1,#mermaid-svg-9bC5cWBSHzIx8H9j .taskText2,#mermaid-svg-9bC5cWBSHzIx8H9j .taskText3{fill:#fff}#mermaid-svg-9bC5cWBSHzIx8H9j .task0,#mermaid-svg-9bC5cWBSHzIx8H9j .task1,#mermaid-svg-9bC5cWBSHzIx8H9j .task2,#mermaid-svg-9bC5cWBSHzIx8H9j .task3{fill:#8a90dd;stroke:#534fbc}#mermaid-svg-9bC5cWBSHzIx8H9j .taskTextOutside0,#mermaid-svg-9bC5cWBSHzIx8H9j .taskTextOutside2{fill:#000}#mermaid-svg-9bC5cWBSHzIx8H9j .taskTextOutside1,#mermaid-svg-9bC5cWBSHzIx8H9j .taskTextOutside3{fill:#000}#mermaid-svg-9bC5cWBSHzIx8H9j .active0,#mermaid-svg-9bC5cWBSHzIx8H9j .active1,#mermaid-svg-9bC5cWBSHzIx8H9j .active2,#mermaid-svg-9bC5cWBSHzIx8H9j .active3{fill:#bfc7ff;stroke:#534fbc}#mermaid-svg-9bC5cWBSHzIx8H9j .activeText0,#mermaid-svg-9bC5cWBSHzIx8H9j .activeText1,#mermaid-svg-9bC5cWBSHzIx8H9j .activeText2,#mermaid-svg-9bC5cWBSHzIx8H9j .activeText3{fill:#000 !important}#mermaid-svg-9bC5cWBSHzIx8H9j .done0,#mermaid-svg-9bC5cWBSHzIx8H9j .done1,#mermaid-svg-9bC5cWBSHzIx8H9j .done2,#mermaid-svg-9bC5cWBSHzIx8H9j .done3{stroke:grey;fill:#d3d3d3;stroke-width:2}#mermaid-svg-9bC5cWBSHzIx8H9j .doneText0,#mermaid-svg-9bC5cWBSHzIx8H9j .doneText1,#mermaid-svg-9bC5cWBSHzIx8H9j .doneText2,#mermaid-svg-9bC5cWBSHzIx8H9j .doneText3{fill:#000 !important}#mermaid-svg-9bC5cWBSHzIx8H9j .crit0,#mermaid-svg-9bC5cWBSHzIx8H9j .crit1,#mermaid-svg-9bC5cWBSHzIx8H9j .crit2,#mermaid-svg-9bC5cWBSHzIx8H9j .crit3{stroke:#f88;fill:red;stroke-width:2}#mermaid-svg-9bC5cWBSHzIx8H9j .activeCrit0,#mermaid-svg-9bC5cWBSHzIx8H9j .activeCrit1,#mermaid-svg-9bC5cWBSHzIx8H9j .activeCrit2,#mermaid-svg-9bC5cWBSHzIx8H9j .activeCrit3{stroke:#f88;fill:#bfc7ff;stroke-width:2}#mermaid-svg-9bC5cWBSHzIx8H9j .doneCrit0,#mermaid-svg-9bC5cWBSHzIx8H9j .doneCrit1,#mermaid-svg-9bC5cWBSHzIx8H9j .doneCrit2,#mermaid-svg-9bC5cWBSHzIx8H9j .doneCrit3{stroke:#f88;fill:#d3d3d3;stroke-width:2;cursor:pointer;shape-rendering:crispEdges}#mermaid-svg-9bC5cWBSHzIx8H9j .milestone{transform:rotate(45deg) scale(0.8, 0.8)}#mermaid-svg-9bC5cWBSHzIx8H9j .milestoneText{font-style:italic}#mermaid-svg-9bC5cWBSHzIx8H9j .doneCritText0,#mermaid-svg-9bC5cWBSHzIx8H9j .doneCritText1,#mermaid-svg-9bC5cWBSHzIx8H9j .doneCritText2,#mermaid-svg-9bC5cWBSHzIx8H9j .doneCritText3{fill:#000 !important}#mermaid-svg-9bC5cWBSHzIx8H9j .activeCritText0,#mermaid-svg-9bC5cWBSHzIx8H9j .activeCritText1,#mermaid-svg-9bC5cWBSHzIx8H9j .activeCritText2,#mermaid-svg-9bC5cWBSHzIx8H9j .activeCritText3{fill:#000 !important}#mermaid-svg-9bC5cWBSHzIx8H9j .titleText{text-anchor:middle;font-size:18px;fill:#000;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-9bC5cWBSHzIx8H9j g.classGroup text{fill:#9370db;stroke:none;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);font-size:10px}#mermaid-svg-9bC5cWBSHzIx8H9j g.classGroup text .title{font-weight:bolder}#mermaid-svg-9bC5cWBSHzIx8H9j g.clickable{cursor:pointer}#mermaid-svg-9bC5cWBSHzIx8H9j g.classGroup rect{fill:#ECECFF;stroke:#9370db}#mermaid-svg-9bC5cWBSHzIx8H9j g.classGroup line{stroke:#9370db;stroke-width:1}#mermaid-svg-9bC5cWBSHzIx8H9j .classLabel .box{stroke:none;stroke-width:0;fill:#ECECFF;opacity:0.5}#mermaid-svg-9bC5cWBSHzIx8H9j .classLabel .label{fill:#9370db;font-size:10px}#mermaid-svg-9bC5cWBSHzIx8H9j .relation{stroke:#9370db;stroke-width:1;fill:none}#mermaid-svg-9bC5cWBSHzIx8H9j .dashed-line{stroke-dasharray:3}#mermaid-svg-9bC5cWBSHzIx8H9j #compositionStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-9bC5cWBSHzIx8H9j #compositionEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-9bC5cWBSHzIx8H9j #aggregationStart{fill:#ECECFF;stroke:#9370db;stroke-width:1}#mermaid-svg-9bC5cWBSHzIx8H9j #aggregationEnd{fill:#ECECFF;stroke:#9370db;stroke-width:1}#mermaid-svg-9bC5cWBSHzIx8H9j #dependencyStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-9bC5cWBSHzIx8H9j #dependencyEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-9bC5cWBSHzIx8H9j #extensionStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-9bC5cWBSHzIx8H9j #extensionEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-9bC5cWBSHzIx8H9j .commit-id,#mermaid-svg-9bC5cWBSHzIx8H9j .commit-msg,#mermaid-svg-9bC5cWBSHzIx8H9j .branch-label{fill:lightgrey;color:lightgrey;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-9bC5cWBSHzIx8H9j .pieTitleText{text-anchor:middle;font-size:25px;fill:#000;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-9bC5cWBSHzIx8H9j .slice{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-9bC5cWBSHzIx8H9j g.stateGroup text{fill:#9370db;stroke:none;font-size:10px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-9bC5cWBSHzIx8H9j g.stateGroup text{fill:#9370db;fill:#333;stroke:none;font-size:10px}#mermaid-svg-9bC5cWBSHzIx8H9j g.statediagram-cluster .cluster-label text{fill:#333}#mermaid-svg-9bC5cWBSHzIx8H9j g.stateGroup .state-title{font-weight:bolder;fill:#000}#mermaid-svg-9bC5cWBSHzIx8H9j g.stateGroup rect{fill:#ECECFF;stroke:#9370db}#mermaid-svg-9bC5cWBSHzIx8H9j g.stateGroup line{stroke:#9370db;stroke-width:1}#mermaid-svg-9bC5cWBSHzIx8H9j .transition{stroke:#9370db;stroke-width:1;fill:none}#mermaid-svg-9bC5cWBSHzIx8H9j .stateGroup .composit{fill:white;border-bottom:1px}#mermaid-svg-9bC5cWBSHzIx8H9j .stateGroup .alt-composit{fill:#e0e0e0;border-bottom:1px}#mermaid-svg-9bC5cWBSHzIx8H9j .state-note{stroke:#aa3;fill:#fff5ad}#mermaid-svg-9bC5cWBSHzIx8H9j .state-note text{fill:black;stroke:none;font-size:10px}#mermaid-svg-9bC5cWBSHzIx8H9j .stateLabel .box{stroke:none;stroke-width:0;fill:#ECECFF;opacity:0.7}#mermaid-svg-9bC5cWBSHzIx8H9j .edgeLabel text{fill:#333}#mermaid-svg-9bC5cWBSHzIx8H9j .stateLabel text{fill:#000;font-size:10px;font-weight:bold;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-9bC5cWBSHzIx8H9j .node circle.state-start{fill:black;stroke:black}#mermaid-svg-9bC5cWBSHzIx8H9j .node circle.state-end{fill:black;stroke:white;stroke-width:1.5}#mermaid-svg-9bC5cWBSHzIx8H9j #statediagram-barbEnd{fill:#9370db}#mermaid-svg-9bC5cWBSHzIx8H9j .statediagram-cluster rect{fill:#ECECFF;stroke:#9370db;stroke-width:1px}#mermaid-svg-9bC5cWBSHzIx8H9j .statediagram-cluster rect.outer{rx:5px;ry:5px}#mermaid-svg-9bC5cWBSHzIx8H9j .statediagram-state .divider{stroke:#9370db}#mermaid-svg-9bC5cWBSHzIx8H9j .statediagram-state .title-state{rx:5px;ry:5px}#mermaid-svg-9bC5cWBSHzIx8H9j .statediagram-cluster.statediagram-cluster .inner{fill:white}#mermaid-svg-9bC5cWBSHzIx8H9j .statediagram-cluster.statediagram-cluster-alt .inner{fill:#e0e0e0}#mermaid-svg-9bC5cWBSHzIx8H9j .statediagram-cluster .inner{rx:0;ry:0}#mermaid-svg-9bC5cWBSHzIx8H9j .statediagram-state rect.basic{rx:5px;ry:5px}#mermaid-svg-9bC5cWBSHzIx8H9j .statediagram-state rect.divider{stroke-dasharray:10,10;fill:#efefef}#mermaid-svg-9bC5cWBSHzIx8H9j .note-edge{stroke-dasharray:5}#mermaid-svg-9bC5cWBSHzIx8H9j .statediagram-note rect{fill:#fff5ad;stroke:#aa3;stroke-width:1px;rx:0;ry:0}:root{--mermaid-font-family: '"trebuchet ms", verdana, arial';--mermaid-font-family: "Comic Sans MS", "Comic Sans", cursive}#mermaid-svg-9bC5cWBSHzIx8H9j .error-icon{fill:#522}#mermaid-svg-9bC5cWBSHzIx8H9j .error-text{fill:#522;stroke:#522}#mermaid-svg-9bC5cWBSHzIx8H9j .edge-thickness-normal{stroke-width:2px}#mermaid-svg-9bC5cWBSHzIx8H9j .edge-thickness-thick{stroke-width:3.5px}#mermaid-svg-9bC5cWBSHzIx8H9j .edge-pattern-solid{stroke-dasharray:0}#mermaid-svg-9bC5cWBSHzIx8H9j .edge-pattern-dashed{stroke-dasharray:3}#mermaid-svg-9bC5cWBSHzIx8H9j .edge-pattern-dotted{stroke-dasharray:2}#mermaid-svg-9bC5cWBSHzIx8H9j .marker{fill:#333}#mermaid-svg-9bC5cWBSHzIx8H9j .marker.cross{stroke:#333}:root { --mermaid-font-family: "trebuchet ms", verdana, arial;}#mermaid-svg-9bC5cWBSHzIx8H9j {color: rgba(0, 0, 0, 0.75);font: ;}张三李四王五你好!李四, 最近怎么样?你最近怎么样,王五?我很好,谢谢!我很好,谢谢!李四想了很长时间, 文字太长了不适合放在一行.打量着王五...很好... 王五, 你怎么样?张三李四王五

这将产生一个流程图。:

#mermaid-svg-C8lnWWDdFI8ZZRqg .label{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);fill:#333;color:#333}#mermaid-svg-C8lnWWDdFI8ZZRqg .label text{fill:#333}#mermaid-svg-C8lnWWDdFI8ZZRqg .node rect,#mermaid-svg-C8lnWWDdFI8ZZRqg .node circle,#mermaid-svg-C8lnWWDdFI8ZZRqg .node ellipse,#mermaid-svg-C8lnWWDdFI8ZZRqg .node polygon,#mermaid-svg-C8lnWWDdFI8ZZRqg .node path{fill:#ECECFF;stroke:#9370db;stroke-width:1px}#mermaid-svg-C8lnWWDdFI8ZZRqg .node .label{text-align:center;fill:#333}#mermaid-svg-C8lnWWDdFI8ZZRqg .node.clickable{cursor:pointer}#mermaid-svg-C8lnWWDdFI8ZZRqg .arrowheadPath{fill:#333}#mermaid-svg-C8lnWWDdFI8ZZRqg .edgePath .path{stroke:#333;stroke-width:1.5px}#mermaid-svg-C8lnWWDdFI8ZZRqg .flowchart-link{stroke:#333;fill:none}#mermaid-svg-C8lnWWDdFI8ZZRqg .edgeLabel{background-color:#e8e8e8;text-align:center}#mermaid-svg-C8lnWWDdFI8ZZRqg .edgeLabel rect{opacity:0.9}#mermaid-svg-C8lnWWDdFI8ZZRqg .edgeLabel span{color:#333}#mermaid-svg-C8lnWWDdFI8ZZRqg .cluster rect{fill:#ffffde;stroke:#aa3;stroke-width:1px}#mermaid-svg-C8lnWWDdFI8ZZRqg .cluster text{fill:#333}#mermaid-svg-C8lnWWDdFI8ZZRqg div.mermaidTooltip{position:absolute;text-align:center;max-width:200px;padding:2px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);font-size:12px;background:#ffffde;border:1px solid #aa3;border-radius:2px;pointer-events:none;z-index:100}#mermaid-svg-C8lnWWDdFI8ZZRqg .actor{stroke:#ccf;fill:#ECECFF}#mermaid-svg-C8lnWWDdFI8ZZRqg text.actor>tspan{fill:#000;stroke:none}#mermaid-svg-C8lnWWDdFI8ZZRqg .actor-line{stroke:grey}#mermaid-svg-C8lnWWDdFI8ZZRqg .messageLine0{stroke-width:1.5;stroke-dasharray:none;stroke:#333}#mermaid-svg-C8lnWWDdFI8ZZRqg .messageLine1{stroke-width:1.5;stroke-dasharray:2, 2;stroke:#333}#mermaid-svg-C8lnWWDdFI8ZZRqg #arrowhead path{fill:#333;stroke:#333}#mermaid-svg-C8lnWWDdFI8ZZRqg .sequenceNumber{fill:#fff}#mermaid-svg-C8lnWWDdFI8ZZRqg #sequencenumber{fill:#333}#mermaid-svg-C8lnWWDdFI8ZZRqg #crosshead path{fill:#333;stroke:#333}#mermaid-svg-C8lnWWDdFI8ZZRqg .messageText{fill:#333;stroke:#333}#mermaid-svg-C8lnWWDdFI8ZZRqg .labelBox{stroke:#ccf;fill:#ECECFF}#mermaid-svg-C8lnWWDdFI8ZZRqg .labelText,#mermaid-svg-C8lnWWDdFI8ZZRqg .labelText>tspan{fill:#000;stroke:none}#mermaid-svg-C8lnWWDdFI8ZZRqg .loopText,#mermaid-svg-C8lnWWDdFI8ZZRqg .loopText>tspan{fill:#000;stroke:none}#mermaid-svg-C8lnWWDdFI8ZZRqg .loopLine{stroke-width:2px;stroke-dasharray:2, 2;stroke:#ccf;fill:#ccf}#mermaid-svg-C8lnWWDdFI8ZZRqg .note{stroke:#aa3;fill:#fff5ad}#mermaid-svg-C8lnWWDdFI8ZZRqg .noteText,#mermaid-svg-C8lnWWDdFI8ZZRqg .noteText>tspan{fill:#000;stroke:none}#mermaid-svg-C8lnWWDdFI8ZZRqg .activation0{fill:#f4f4f4;stroke:#666}#mermaid-svg-C8lnWWDdFI8ZZRqg .activation1{fill:#f4f4f4;stroke:#666}#mermaid-svg-C8lnWWDdFI8ZZRqg .activation2{fill:#f4f4f4;stroke:#666}#mermaid-svg-C8lnWWDdFI8ZZRqg .mermaid-main-font{font-family:"trebuchet ms", verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-C8lnWWDdFI8ZZRqg .section{stroke:none;opacity:0.2}#mermaid-svg-C8lnWWDdFI8ZZRqg .section0{fill:rgba(102,102,255,0.49)}#mermaid-svg-C8lnWWDdFI8ZZRqg .section2{fill:#fff400}#mermaid-svg-C8lnWWDdFI8ZZRqg .section1,#mermaid-svg-C8lnWWDdFI8ZZRqg .section3{fill:#fff;opacity:0.2}#mermaid-svg-C8lnWWDdFI8ZZRqg .sectionTitle0{fill:#333}#mermaid-svg-C8lnWWDdFI8ZZRqg .sectionTitle1{fill:#333}#mermaid-svg-C8lnWWDdFI8ZZRqg .sectionTitle2{fill:#333}#mermaid-svg-C8lnWWDdFI8ZZRqg .sectionTitle3{fill:#333}#mermaid-svg-C8lnWWDdFI8ZZRqg .sectionTitle{text-anchor:start;font-size:11px;text-height:14px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-C8lnWWDdFI8ZZRqg .grid .tick{stroke:#d3d3d3;opacity:0.8;shape-rendering:crispEdges}#mermaid-svg-C8lnWWDdFI8ZZRqg .grid .tick text{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-C8lnWWDdFI8ZZRqg .grid path{stroke-width:0}#mermaid-svg-C8lnWWDdFI8ZZRqg .today{fill:none;stroke:red;stroke-width:2px}#mermaid-svg-C8lnWWDdFI8ZZRqg .task{stroke-width:2}#mermaid-svg-C8lnWWDdFI8ZZRqg .taskText{text-anchor:middle;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-C8lnWWDdFI8ZZRqg .taskText:not([font-size]){font-size:11px}#mermaid-svg-C8lnWWDdFI8ZZRqg .taskTextOutsideRight{fill:#000;text-anchor:start;font-size:11px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-C8lnWWDdFI8ZZRqg .taskTextOutsideLeft{fill:#000;text-anchor:end;font-size:11px}#mermaid-svg-C8lnWWDdFI8ZZRqg .task.clickable{cursor:pointer}#mermaid-svg-C8lnWWDdFI8ZZRqg .taskText.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-C8lnWWDdFI8ZZRqg .taskTextOutsideLeft.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-C8lnWWDdFI8ZZRqg .taskTextOutsideRight.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-C8lnWWDdFI8ZZRqg .taskText0,#mermaid-svg-C8lnWWDdFI8ZZRqg .taskText1,#mermaid-svg-C8lnWWDdFI8ZZRqg .taskText2,#mermaid-svg-C8lnWWDdFI8ZZRqg .taskText3{fill:#fff}#mermaid-svg-C8lnWWDdFI8ZZRqg .task0,#mermaid-svg-C8lnWWDdFI8ZZRqg .task1,#mermaid-svg-C8lnWWDdFI8ZZRqg .task2,#mermaid-svg-C8lnWWDdFI8ZZRqg .task3{fill:#8a90dd;stroke:#534fbc}#mermaid-svg-C8lnWWDdFI8ZZRqg .taskTextOutside0,#mermaid-svg-C8lnWWDdFI8ZZRqg .taskTextOutside2{fill:#000}#mermaid-svg-C8lnWWDdFI8ZZRqg .taskTextOutside1,#mermaid-svg-C8lnWWDdFI8ZZRqg .taskTextOutside3{fill:#000}#mermaid-svg-C8lnWWDdFI8ZZRqg .active0,#mermaid-svg-C8lnWWDdFI8ZZRqg .active1,#mermaid-svg-C8lnWWDdFI8ZZRqg .active2,#mermaid-svg-C8lnWWDdFI8ZZRqg .active3{fill:#bfc7ff;stroke:#534fbc}#mermaid-svg-C8lnWWDdFI8ZZRqg .activeText0,#mermaid-svg-C8lnWWDdFI8ZZRqg .activeText1,#mermaid-svg-C8lnWWDdFI8ZZRqg .activeText2,#mermaid-svg-C8lnWWDdFI8ZZRqg .activeText3{fill:#000 !important}#mermaid-svg-C8lnWWDdFI8ZZRqg .done0,#mermaid-svg-C8lnWWDdFI8ZZRqg .done1,#mermaid-svg-C8lnWWDdFI8ZZRqg .done2,#mermaid-svg-C8lnWWDdFI8ZZRqg .done3{stroke:grey;fill:#d3d3d3;stroke-width:2}#mermaid-svg-C8lnWWDdFI8ZZRqg .doneText0,#mermaid-svg-C8lnWWDdFI8ZZRqg .doneText1,#mermaid-svg-C8lnWWDdFI8ZZRqg .doneText2,#mermaid-svg-C8lnWWDdFI8ZZRqg .doneText3{fill:#000 !important}#mermaid-svg-C8lnWWDdFI8ZZRqg .crit0,#mermaid-svg-C8lnWWDdFI8ZZRqg .crit1,#mermaid-svg-C8lnWWDdFI8ZZRqg .crit2,#mermaid-svg-C8lnWWDdFI8ZZRqg .crit3{stroke:#f88;fill:red;stroke-width:2}#mermaid-svg-C8lnWWDdFI8ZZRqg .activeCrit0,#mermaid-svg-C8lnWWDdFI8ZZRqg .activeCrit1,#mermaid-svg-C8lnWWDdFI8ZZRqg .activeCrit2,#mermaid-svg-C8lnWWDdFI8ZZRqg .activeCrit3{stroke:#f88;fill:#bfc7ff;stroke-width:2}#mermaid-svg-C8lnWWDdFI8ZZRqg .doneCrit0,#mermaid-svg-C8lnWWDdFI8ZZRqg .doneCrit1,#mermaid-svg-C8lnWWDdFI8ZZRqg .doneCrit2,#mermaid-svg-C8lnWWDdFI8ZZRqg .doneCrit3{stroke:#f88;fill:#d3d3d3;stroke-width:2;cursor:pointer;shape-rendering:crispEdges}#mermaid-svg-C8lnWWDdFI8ZZRqg .milestone{transform:rotate(45deg) scale(0.8, 0.8)}#mermaid-svg-C8lnWWDdFI8ZZRqg .milestoneText{font-style:italic}#mermaid-svg-C8lnWWDdFI8ZZRqg .doneCritText0,#mermaid-svg-C8lnWWDdFI8ZZRqg .doneCritText1,#mermaid-svg-C8lnWWDdFI8ZZRqg .doneCritText2,#mermaid-svg-C8lnWWDdFI8ZZRqg .doneCritText3{fill:#000 !important}#mermaid-svg-C8lnWWDdFI8ZZRqg .activeCritText0,#mermaid-svg-C8lnWWDdFI8ZZRqg .activeCritText1,#mermaid-svg-C8lnWWDdFI8ZZRqg .activeCritText2,#mermaid-svg-C8lnWWDdFI8ZZRqg .activeCritText3{fill:#000 !important}#mermaid-svg-C8lnWWDdFI8ZZRqg .titleText{text-anchor:middle;font-size:18px;fill:#000;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-C8lnWWDdFI8ZZRqg g.classGroup text{fill:#9370db;stroke:none;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);font-size:10px}#mermaid-svg-C8lnWWDdFI8ZZRqg g.classGroup text .title{font-weight:bolder}#mermaid-svg-C8lnWWDdFI8ZZRqg g.clickable{cursor:pointer}#mermaid-svg-C8lnWWDdFI8ZZRqg g.classGroup rect{fill:#ECECFF;stroke:#9370db}#mermaid-svg-C8lnWWDdFI8ZZRqg g.classGroup line{stroke:#9370db;stroke-width:1}#mermaid-svg-C8lnWWDdFI8ZZRqg .classLabel .box{stroke:none;stroke-width:0;fill:#ECECFF;opacity:0.5}#mermaid-svg-C8lnWWDdFI8ZZRqg .classLabel .label{fill:#9370db;font-size:10px}#mermaid-svg-C8lnWWDdFI8ZZRqg .relation{stroke:#9370db;stroke-width:1;fill:none}#mermaid-svg-C8lnWWDdFI8ZZRqg .dashed-line{stroke-dasharray:3}#mermaid-svg-C8lnWWDdFI8ZZRqg #compositionStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-C8lnWWDdFI8ZZRqg #compositionEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-C8lnWWDdFI8ZZRqg #aggregationStart{fill:#ECECFF;stroke:#9370db;stroke-width:1}#mermaid-svg-C8lnWWDdFI8ZZRqg #aggregationEnd{fill:#ECECFF;stroke:#9370db;stroke-width:1}#mermaid-svg-C8lnWWDdFI8ZZRqg #dependencyStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-C8lnWWDdFI8ZZRqg #dependencyEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-C8lnWWDdFI8ZZRqg #extensionStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-C8lnWWDdFI8ZZRqg #extensionEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-C8lnWWDdFI8ZZRqg .commit-id,#mermaid-svg-C8lnWWDdFI8ZZRqg .commit-msg,#mermaid-svg-C8lnWWDdFI8ZZRqg .branch-label{fill:lightgrey;color:lightgrey;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-C8lnWWDdFI8ZZRqg .pieTitleText{text-anchor:middle;font-size:25px;fill:#000;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-C8lnWWDdFI8ZZRqg .slice{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-C8lnWWDdFI8ZZRqg g.stateGroup text{fill:#9370db;stroke:none;font-size:10px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-C8lnWWDdFI8ZZRqg g.stateGroup text{fill:#9370db;fill:#333;stroke:none;font-size:10px}#mermaid-svg-C8lnWWDdFI8ZZRqg g.statediagram-cluster .cluster-label text{fill:#333}#mermaid-svg-C8lnWWDdFI8ZZRqg g.stateGroup .state-title{font-weight:bolder;fill:#000}#mermaid-svg-C8lnWWDdFI8ZZRqg g.stateGroup rect{fill:#ECECFF;stroke:#9370db}#mermaid-svg-C8lnWWDdFI8ZZRqg g.stateGroup line{stroke:#9370db;stroke-width:1}#mermaid-svg-C8lnWWDdFI8ZZRqg .transition{stroke:#9370db;stroke-width:1;fill:none}#mermaid-svg-C8lnWWDdFI8ZZRqg .stateGroup .composit{fill:white;border-bottom:1px}#mermaid-svg-C8lnWWDdFI8ZZRqg .stateGroup .alt-composit{fill:#e0e0e0;border-bottom:1px}#mermaid-svg-C8lnWWDdFI8ZZRqg .state-note{stroke:#aa3;fill:#fff5ad}#mermaid-svg-C8lnWWDdFI8ZZRqg .state-note text{fill:black;stroke:none;font-size:10px}#mermaid-svg-C8lnWWDdFI8ZZRqg .stateLabel .box{stroke:none;stroke-width:0;fill:#ECECFF;opacity:0.7}#mermaid-svg-C8lnWWDdFI8ZZRqg .edgeLabel text{fill:#333}#mermaid-svg-C8lnWWDdFI8ZZRqg .stateLabel text{fill:#000;font-size:10px;font-weight:bold;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-C8lnWWDdFI8ZZRqg .node circle.state-start{fill:black;stroke:black}#mermaid-svg-C8lnWWDdFI8ZZRqg .node circle.state-end{fill:black;stroke:white;stroke-width:1.5}#mermaid-svg-C8lnWWDdFI8ZZRqg #statediagram-barbEnd{fill:#9370db}#mermaid-svg-C8lnWWDdFI8ZZRqg .statediagram-cluster rect{fill:#ECECFF;stroke:#9370db;stroke-width:1px}#mermaid-svg-C8lnWWDdFI8ZZRqg .statediagram-cluster rect.outer{rx:5px;ry:5px}#mermaid-svg-C8lnWWDdFI8ZZRqg .statediagram-state .divider{stroke:#9370db}#mermaid-svg-C8lnWWDdFI8ZZRqg .statediagram-state .title-state{rx:5px;ry:5px}#mermaid-svg-C8lnWWDdFI8ZZRqg .statediagram-cluster.statediagram-cluster .inner{fill:white}#mermaid-svg-C8lnWWDdFI8ZZRqg .statediagram-cluster.statediagram-cluster-alt .inner{fill:#e0e0e0}#mermaid-svg-C8lnWWDdFI8ZZRqg .statediagram-cluster .inner{rx:0;ry:0}#mermaid-svg-C8lnWWDdFI8ZZRqg .statediagram-state rect.basic{rx:5px;ry:5px}#mermaid-svg-C8lnWWDdFI8ZZRqg .statediagram-state rect.divider{stroke-dasharray:10,10;fill:#efefef}#mermaid-svg-C8lnWWDdFI8ZZRqg .note-edge{stroke-dasharray:5}#mermaid-svg-C8lnWWDdFI8ZZRqg .statediagram-note rect{fill:#fff5ad;stroke:#aa3;stroke-width:1px;rx:0;ry:0}:root{--mermaid-font-family: '"trebuchet ms", verdana, arial';--mermaid-font-family: "Comic Sans MS", "Comic Sans", cursive}#mermaid-svg-C8lnWWDdFI8ZZRqg .error-icon{fill:#522}#mermaid-svg-C8lnWWDdFI8ZZRqg .error-text{fill:#522;stroke:#522}#mermaid-svg-C8lnWWDdFI8ZZRqg .edge-thickness-normal{stroke-width:2px}#mermaid-svg-C8lnWWDdFI8ZZRqg .edge-thickness-thick{stroke-width:3.5px}#mermaid-svg-C8lnWWDdFI8ZZRqg .edge-pattern-solid{stroke-dasharray:0}#mermaid-svg-C8lnWWDdFI8ZZRqg .edge-pattern-dashed{stroke-dasharray:3}#mermaid-svg-C8lnWWDdFI8ZZRqg .edge-pattern-dotted{stroke-dasharray:2}#mermaid-svg-C8lnWWDdFI8ZZRqg .marker{fill:#333}#mermaid-svg-C8lnWWDdFI8ZZRqg .marker.cross{stroke:#333}:root { --mermaid-font-family: "trebuchet ms", verdana, arial;}#mermaid-svg-C8lnWWDdFI8ZZRqg {color: rgba(0, 0, 0, 0.75);font: ;}

链接
长方形
圆角长方形
菱形
  • 关于 Mermaid 语法,参考 这儿,

FLowchart流程图

我们依旧会支持flowchart的流程图:

Created with Raphaël 2.3.0开始我的操作确认?结束yesno
  • 关于 Flowchart流程图 语法,参考 这儿.

导出与导入

导出

如果你想尝试使用此编辑器, 你可以在此篇文章任意编辑。当你完成了一篇文章的写作, 在上方工具栏找到 文章导出 ,生成一个.md文件或者.html文件进行本地保存。

导入

如果你想加载一篇你写过的.md文件,在上方工具栏可以选择导入功能进行对应扩展名的文件导入,
继续你的创作。


  1. mermaid语法说明 ↩︎

  2. 注脚的解释 ↩︎

2021-11-01 Apathe POI相关推荐

  1. 【财经期刊FM-Radio|2021年01月19日】

    title: [财经期刊FM-Radio|2021年01月19日] 微信公众号: 张良信息咨询服务工作室 [今日热点新闻一览↓↓] 美股美债休市,欧股走出逾一周低谷,雪铁龙并购后新公司登陆欧股首日涨超 ...

  2. 实战:怎样把间隔的几个commit整理成1个?-2021.11.18

    实战:怎样把间隔的几个commit整理成1个?-2021.11.18 目录 文章目录 实战:怎样把间隔的几个commit整理成1个?-2021.11.18 目录 文档来源 实验环境 实验软件(无) 1 ...

  3. 【财经期刊FM-Radio|2021年01月20日】

    title: [财经期刊FM-Radio|2021年01月20日] 微信公众号: 张良信息咨询服务工作室 [今日热点新闻一览↓↓] 纳指涨超1.5%,中概大涨,腾讯音乐涨21%,金银油回涨,以太币新高 ...

  4. Neovim开发环境搭建(2021.07.01)

    Neovim开发环境搭建(2021.07.01) 一.搭建环境 Ubuntu 21.04 Neovim 0.4.4 二.Neovim安装 # 下载 neovim,如遇网络问题可以采用 https:// ...

  5. 史上最详细微信小程序授权登录与后端SprIngBoot交互操作说明,附源代码,有疑惑大家可以直接留言,蟹蟹 2021.11.29完善更新小程序代码,

    2021.11.29 更新文章 你好,我是博主宁在春,一起学习吧!!! 写这篇文章的原因,主要是因为最近在写毕业设计,用到了小程序,这中间曲曲折折,一言难尽啊.毕业设计真的让人麻脑阔

  6. 验证码 -图形图像识别的算法。http://blog.csdn.net/xtalk2008/archive/2007/11/01/1861310.aspx...

    验证码 -图形图像识别的算法.http://blog.csdn.net/xtalk2008/archive/2007/11/01/1861310.aspx 图像经过处理后,还需要进行分割,才能进行比较 ...

  7. 读论文——Pre-Training with Whole Word Masking for Chinese BERT(2021 11.25)

    第一遍 标题以及作者(2021 11.25) 摘要 本文基于BERT,在RoBERTa上进行一系列改进,提出了用于中文的预训练模型MacBERT. 提出了一种新的掩码策略,MLM as correct ...

  8. 首页推荐流支持快捷修改兴趣标签,问答支持展示gif【2021.11.8】

    hello,大家好,这里是「CSDN产品周报」第17期.本次更新主要涉及首页和问答两个产品模块,具体细节请往下看. 一.首页优化 1.「推荐」信息流新增「修改兴趣标签」按钮 从用户需求的角度考虑,对内 ...

  9. 【报告分享】小红书平台2021 11.11期间行业投放分析报告-千瓜数据(附下载)

    摘要:随着平台多元化发展,用户体量增加,小红书逐渐拥抱了更多的年轻用户群体,也给更多的品牌带来了增长机会.据小红书方透露,2021年小红书平台的单日笔记曝光已经超100亿次,且男性用户占比已经达到了3 ...

  10. 2021.11.8-11.14 AI行业周刊(第71期):AI行业经验

    篇章一:行业经验 不同的AI公司,对于AI产品的场景定位不同. 有的公司是面向C端产品.有的公司专门做B端用户. 当然大白所在的公司,也有具体的定位,主要面向智慧金融.智慧机场.智慧城市. 之前,一直 ...

最新文章

  1. Udacity机器人软件工程师课程笔记(二十八) - 卷积神经网络实例 - Fashion-MNIST数据集
  2. linux下mysql主从复制搭建
  3. thinkphp5 使用PHPExcel 导入导出
  4. C++ 虚拟析构函数
  5. gpu无法调用解决方案记录
  6. 树形结构:二叉排列树,二叉搜索树
  7. Python基础教程学习笔记:第二章 列表和元组
  8. android工作机制和内核,android内核剖析学习笔记:AMS(ActivityManagerService)内部原理和工作机制...
  9. Spring和Hibernate的自定义审核日志
  10. 测试Markdown
  11. LeetCode Solutions : Reorder List
  12. go语言sleep一纳秒不准的思考--CPU时间片
  13. linux文本模式无法打字,文本终端模式下中文输入法(Fcitx)配置(openSUSE Leap 42.1)...
  14. springmvc + ehcache + redis+mybatis 分布式架构
  15. matlab的简单使用-matlab画f(x)=x^2+y^2的图像
  16. [转载] 之前碰过的木马分析
  17. ubuntu20.04.1下安装qt4相关依赖库
  18. c语言ip判断程序,IP判断 (C语言代码)
  19. 使用java自动下载网易云音乐
  20. Android自定义View_绘制菱形图片

热门文章

  1. 浅谈Cache Memory--目录
  2. 商汤发布象棋机器人『元萝卜』;『南瓜书』西瓜书公式推导解析;代码自动美化插件;Tock建立对话机器人的AI平台;前沿论文 | ShowMeAI资讯日报
  3. 使用python进行数据分析可视化入门指南
  4. caffe for windows的matlab接口(四):权重和特征图可视化的一个例子
  5. 超市购物消费清单打印的实现
  6. 计算机博士生交换,博士期间出国交换一年,真的有用吗?
  7. 【考研经验】19制药跨考【东南大学】软件专硕,真实考研经历以及跨考菜鸡的迷茫记录!...
  8. 扫雷游戏地雷数计算(模拟)
  9. 积木题 (2017年秋季——某网站的面试笔试题)
  10. 《Android 第一行代码》十一章 “服务的最佳实践”