htmlParser 解析Table

 

 

String monitorContent = "<TABLE style="WIDTH: 100%" id=MachineEnvInfo>
<TBODY>
<TR>
<TD class=th></TD>
<TD class=th>机房</TD>
<TD class=th>温度</TD>
<TD class=th>湿度</TD></TR>
<TBODY>
<TR>
<TD class=thh rowSpan=18>机房环境信息</TD>
<TD class=td><INPUT class=input value="21F 通信勤务机房" size=45 name=email></TD>
<TD class=td><INPUT class=input value=25.85 size=25 name=email></TD>
<TD class=td><INPUT class=input value=57.95 size=25 name=email></TD></TR>
<TR>
</TABLE>"

Parser parser = new Parser();

		try {
			parser.setInputHTML(monitorContent);
		} catch (ParserException e) {
			e.printStackTrace();
		}

		NodeList tableTags = parser.parse(new NodeClassFilter(TableTag.class));

		for (int i = 0; i < tableTags.size(); i++) {
			TableTag tableTag = (TableTag) tableTags.elementAt(i);
			NodeList childList = tableTag.getChildren();
			for (int j = 0; j < childList.size(); j++) {
				Tag childTag = (Tag) childList.elementAt(j);
				if (childTag.getTagName().equals("TR") || childTag.getTagName().equals("tr")) {
					NodeList tdList = childTag.getChildren();
					String macRoomName = "";
					String macRoomTemper = "";
					for (int k = 0; k < tdList.size(); k++) {
						Tag tdTag = (Tag) tdList.elementAt(k);
						if (tdTag.getTagName().equals("TD") || tdTag.getTagName().equals("td")) {

							if (k == tdList.size() - 4
									&& tdTag.getChildren().elementAt(0).getClass().getSimpleName().equals("InputTag")) {// 机房是input倒数第三个标签
								Tag macRoomTag = (Tag) tdTag.getChildren().elementAt(0);
								macRoomName = macRoomTag.getAttribute("value");
							}
							if (k == tdList.size() - 3
									&& tdTag.getChildren().elementAt(0).getClass().getSimpleName().equals("InputTag")) {// 温度是input倒数第二个标签
								Tag macRoomTemperTag = (Tag) tdTag.getChildren().elementAt(0);
								macRoomTemper = macRoomTemperTag.getAttribute("value");
							}
						}
					}
					
				}

 

 

 

          需要htmlParser.jar包,解析table里的<tbody><td>等标签 ,判断里面是否存在input标签,此时有定制功能

 

 

 

 

 

 

 

你可能感兴趣的:(HtmlParser)