我有一个很大的XML文件,我正在解析如下:
public class Solution {
private static final String ROOM_ID = "RoomID";
private static final String CONTENT = "Content";
private static final String LOGIN_NAME = "LoginName";
private static final String CONVERSATION_ID = "ConversationID";
private static final String FILE_DUMP = "FileDump";
private static final String MESSAGE = "Message";
private static final String CONVERSATION = "Conversation";
private static final String START_TIME = "StartTime";
static class ConversationInfo {
private String startTimeStr;
private String conversationId;
private String fileName;
private int orderInFile;
private final Set<String> users = new HashSet<>();
private final List<Message> messages = new ArrayList<>();
public HashMap<String, String> map = new HashMap<>();
@Override
public String toString() {
return String.format("%s %d %s %s %s %d %s", fileName, orderInFile, conversationId,
startTimeStr, StringUtils.join(users, "***"), users.size(),
StringUtils.join(messages, "&&&"));
}
}
static class Message {
public final String userName;
public final String content;
public Message(String name, String content) {
this.userName = name;
this.content = content;
}
@Override
public String toString() {
return userName + " " + content;
}
}
public static void main(String[] args)
throws XMLStreamException, IOException {
File folder = new File("/xml/");
List<ConversationInfo> m = new ArrayList<>();
File[] listOfFiles = folder.listFiles();
for (int i = 0; i < listOfFiles.length; i++) {
File file = listOfFiles[i];
String fileName = file.getAbsolutePath();
System.out.println("File" + file);
if (file.isFile() && file.getName().endsWith(".xml")) {
XMLInputFactory xf = XMLInputFactory.newFactory();
try (FileInputStream fin = new FileInputStream(file)) {
XMLStreamReader xr = xf.createXMLStreamReader(fin);
LOOP:
while (xr.hasNext()) {
int event = xr.next();
switch (event) {
case XMLStreamConstants.START_ELEMENT: {
String elName = xr.getLocalName();
if (CONVERSATION.equals(elName)) {
ConversationInfo convInfo = parseConversation(xr, file.getName());
if (convInfo != null) {
m.add(convInfo);
}
}
break;
}
case XMLStreamConstants.END_ELEMENT: {
String elName = xr.getLocalName();
if (FILE_DUMP.equals(elName)) {
break LOOP;
}
break;
}
case XMLStreamConstants.END_DOCUMENT:
throw new IllegalStateException("xml not well-formed: <"
+ FILE_DUMP + "> tag not closed");
}
}
}
}
}
// ConversationInfo c = new ConversationInfo();
try (FileWriter w = new FileWriter("output.txt")) {
int i = 1;
for (ConversationInfo convInfo : m) {
convInfo.orderInFile = i;
w.write(String.format("%d %s\n", i++, convInfo));
}
}
}
private static ConversationInfo parseConversation(XMLStreamReader xr, String fileName)
throws XMLStreamException {
ConversationInfo convInfo = new ConversationInfo();
convInfo.fileName = fileName;
while (xr.hasNext()) {
int event = xr.next();
switch (event) {
case XMLStreamConstants.START_ELEMENT: {
String elName = xr.getLocalName();
if (MESSAGE.equals(elName)) {
Message message = parseMessage(xr);
if (message != null) {
convInfo.messages.add(message);
convInfo.users.add(message.userName);
convInfo.map.put(message.userName, message.content);
}
} else if (START_TIME.equals(elName)) {
convInfo.startTimeStr = xr.getElementText();
} else if (ROOM_ID.equals(elName)) {
convInfo.conversationId = xr.getElementText();
}
break;
}
case XMLStreamConstants.END_ELEMENT: {
String elName = xr.getLocalName();
if (CONVERSATION.equals(elName)) {
return convInfo;
}
break;
}
case XMLStreamConstants.END_DOCUMENT:
throw new XMLStreamException("xml not well-formed: <"
+ CONVERSATION + "> tag not closed");
}
}
throw new XMLStreamException(
"unexpected end of xml file while parsing a conversation");
}
private static Message parseMessage(XMLStreamReader xr)
throws XMLStreamException {
String userName = null;
String content = null;
while (xr.hasNext()) {
int event = xr.next();
switch (event) {
case XMLStreamConstants.START_ELEMENT: {
String elName = xr.getLocalName();
if (LOGIN_NAME.equals(elName)) {
userName = xr.getElementText();
} else if (CONTENT.equals(elName)) {
content = StringUtils.trimToEmpty(xr.getElementText());
}
break;
}
case XMLStreamConstants.END_ELEMENT: {
String elName = xr.getLocalName();
if (MESSAGE.equals(elName)) {
return new Message(userName, content);
}
break;
}
case XMLStreamConstants.END_DOCUMENT:
throw new XMLStreamException("xml not well-formed: <"
+ MESSAGE + "> tag not closed");
}
}
throw new XMLStreamException(
"unexpected end of xml file while parsing a message");
}
}
而我的input.xml
是:
<?xml version="1.0" encoding="UTF-8"?>
<!-- Data provided by Bloomberg LP. -->
<FileDump>
<Version>IBXML 1.3</Version>
<Conversation Perspective=" " RoomType="P">
<RoomID>PCHAT-0x3000001CA8361</RoomID>
<StartTime>03/31/2016 13:39:01</StartTime>
<StartTimeUTC>1459431541</StartTimeUTC>
<ParticipantEntered InteractionType="N" DeviceType="M">
<User>
<LoginName>SWONG00</LoginName>
<FirstName>STEPHEN</FirstName>
<LastName>WONG</LastName>
<UUID>4397109</UUID>
<FirmNumber>13133</FirmNumber>
<AccountNumber>231115</AccountNumber>
<CompanyName>DBS BANK LIMITED HON</CompanyName>
<EmailAddress>SWONG00@Bloomberg.net</EmailAddress>
<CorporateEmailAddress>STEPHENWONGWE@DBS.COM</CorporateEmailAddress>
</User>
<DateTime>03/31/2016 13:39:01</DateTime>
<DateTimeUTC>1459431541</DateTimeUTC>
<ConversationID>PCHAT-0x3000001CA8361</ConversationID>
</ParticipantEntered>
<ParticipantEntered InteractionType="N" DeviceType="M">
<User>
<LoginName>G_LO</LoginName>
<FirstName>GARY</FirstName>
<LastName>LO</LastName>
<UUID>7054548</UUID>
<FirmNumber>13133</FirmNumber>
<AccountNumber>91189</AccountNumber>
<CompanyName>DBS BANK (HONG KONG)</CompanyName>
<EmailAddress>G_LO@Bloomberg.net</EmailAddress>
<CorporateEmailAddress>garyloyc@dbs.com</CorporateEmailAddress>
</User>
<DateTime>03/31/2016 14:56:22</DateTime>
<DateTimeUTC>1459436182</DateTimeUTC>
<ConversationID>PCHAT-0x3000001CA8361</ConversationID>
</ParticipantEntered>
<ParticipantLeft InteractionType="N" DeviceType="M">
<User>
<LoginName>G_LO</LoginName>
<FirstName>GARY</FirstName>
<LastName>LO</LastName>
<UUID>7054548</UUID>
<FirmNumber>13133</FirmNumber>
<AccountNumber>91189</AccountNumber>
<CompanyName>DBS BANK (HONG KONG)</CompanyName>
<EmailAddress>G_LO@Bloomberg.net</EmailAddress>
<CorporateEmailAddress>garyloyc@dbs.com</CorporateEmailAddress>
</User>
<DateTime>03/31/2016 19:30:01</DateTime>
<DateTimeUTC>1459452601</DateTimeUTC>
<ConversationID>PCHAT-0x3000001CA8361</ConversationID>
</ParticipantLeft>
<ParticipantLeft InteractionType="N" DeviceType="M">
<User>
<LoginName>SWONG00</LoginName>
<FirstName>STEPHEN</FirstName>
<LastName>WONG</LastName>
<UUID>4397109</UUID>
<FirmNumber>13133</FirmNumber>
<AccountNumber>231115</AccountNumber>
<CompanyName>DBS BANK LIMITED HON</CompanyName>
<EmailAddress>SWONG00@Bloomberg.net</EmailAddress>
<CorporateEmailAddress>STEPHENWONGWE@DBS.COM</CorporateEmailAddress>
</User>
<DateTime>03/31/2016 19:33:56</DateTime>
<DateTimeUTC>1459452836</DateTimeUTC>
<ConversationID>PCHAT-0x3000001CA8361</ConversationID>
</ParticipantLeft>
<ParticipantEntered InteractionType="N" DeviceType="M">
<User>
<LoginName>SWONG00</LoginName>
<FirstName>STEPHEN</FirstName>
<LastName>WONG</LastName>
<UUID>4397109</UUID>
<FirmNumber>13133</FirmNumber>
<AccountNumber>231115</AccountNumber>
<CompanyName>DBS BANK LIMITED HON</CompanyName>
<EmailAddress>SWONG00@Bloomberg.net</EmailAddress>
<CorporateEmailAddress>STEPHENWONGWE@DBS.COM</CorporateEmailAddress>
</User>
<DateTime>03/31/2016 19:45:16</DateTime>
<DateTimeUTC>1459453516</DateTimeUTC>
<ConversationID>PCHAT-0x3000001CA8361</ConversationID>
</ParticipantEntered>
<ParticipantLeft InteractionType="N" DeviceType="M">
<User>
<LoginName>SWONG00</LoginName>
<FirstName>STEPHEN</FirstName>
<LastName>WONG</LastName>
<UUID>4397109</UUID>
<FirmNumber>13133</FirmNumber>
<AccountNumber>231115</AccountNumber>
<CompanyName>DBS BANK LIMITED HON</CompanyName>
<EmailAddress>SWONG00@Bloomberg.net</EmailAddress>
<CorporateEmailAddress>STEPHENWONGWE@DBS.COM</CorporateEmailAddress>
</User>
<DateTime>03/31/2016 23:08:09</DateTime>
<DateTimeUTC>1459465689</DateTimeUTC>
<ConversationID>PCHAT-0x3000001CA8361</ConversationID>
</ParticipantLeft>
<ParticipantEntered InteractionType="N" DeviceType="M">
<User>
<LoginName>G_LO</LoginName>
<FirstName>GARY</FirstName>
<LastName>LO</LastName>
<UUID>7054548</UUID>
<FirmNumber>13133</FirmNumber>
<AccountNumber>91189</AccountNumber>
<CompanyName>DBS BANK (HONG KONG)</CompanyName>
<EmailAddress>G_LO@Bloomberg.net</EmailAddress>
<CorporateEmailAddress>garyloyc@dbs.com</CorporateEmailAddress>
</User>
<DateTime>03/31/2016 23:14:23</DateTime>
<DateTimeUTC>1459466063</DateTimeUTC>
<ConversationID>PCHAT-0x3000001CA8361</ConversationID>
</ParticipantEntered>
<Message InteractionType="N">
<User>
<LoginName>G_LO</LoginName>
<FirstName>GARY</FirstName>
<LastName>LO</LastName>
<UUID>7054548</UUID>
<FirmNumber>13133</FirmNumber>
<AccountNumber>91189</AccountNumber>
<CompanyName>DBS BANK (HONG KONG)</CompanyName>
<EmailAddress>G_LO@Bloomberg.net</EmailAddress>
<CorporateEmailAddress>garyloyc@dbs.com</CorporateEmailAddress>
</User>
<DateTime>04/01/2016 00:10:57</DateTime>
<DateTimeUTC>1459469457</DateTimeUTC>
<Content>abcdefgghhhhhh</Content>
<ConversationID>PCHAT-0x3000001CA8361</ConversationID>
</Message>
<ParticipantEntered InteractionType="N" DeviceType="M">
<User>
<LoginName>WVU</LoginName>
<FirstName>WHEELOCK</FirstName>
<LastName>VU</LastName>
<UUID>8266852</UUID>
<FirmNumber>13133</FirmNumber>
<AccountNumber>91189</AccountNumber>
<CompanyName>DBS BANK (HONG KONG)</CompanyName>
<EmailAddress>WVU@Bloomberg.net</EmailAddress>
<CorporateEmailAddress>WHEELOCKVU@DBS.COM</CorporateEmailAddress>
</User>
<DateTime>04/01/2016 00:14:05</DateTime>
<DateTimeUTC>1459469645</DateTimeUTC>
<ConversationID>PCHAT-0x3000001CA8361</ConversationID>
</ParticipantEntered>
<ParticipantEntered InteractionType="N">
<User>
<LoginName>FCHAN95</LoginName>
<FirstName>FLORENCE</FirstName>
<LastName>CHAN</LastName>
<CompanyName>GOLDMAN SACHS (ASIA)</CompanyName>
<EmailAddress>FCHAN95@Bloomberg.net</EmailAddress>
<CorporateEmailAddress />
</User>
<DateTime>04/01/2016 00:29:19</DateTime>
<DateTimeUTC>1459470559</DateTimeUTC>
<ConversationID>PCHAT-0x3000001CA8361</ConversationID>
</ParticipantEntered>
<Message InteractionType="N">
<User>
<LoginName>FCHAN95</LoginName>
<FirstName>FLORENCE</FirstName>
<LastName>CHAN</LastName>
<CompanyName>GOLDMAN SACHS (ASIA)</CompanyName>
<EmailAddress>FCHAN95@Bloomberg.net</EmailAddress>
<CorporateEmailAddress />
</User>
<DateTime>04/01/2016 00:29:19</DateTime>
<DateTimeUTC>1459470559</DateTimeUTC>
<Content>ajdakjgdljsgdsafhkafa</Content>
<ConversationID>PCHAT-0x3000001CA8361</ConversationID>
</Message>
<Message InteractionType="N">
<User>
<LoginName>FCHAN95</LoginName>
<FirstName>FLORENCE</FirstName>
<LastName>CHAN</LastName>
<CompanyName>GOLDMAN SACHS (ASIA)</CompanyName>
<EmailAddress>FCHAN95@Bloomberg.net</EmailAddress>
<CorporateEmailAddress />
</User>
<DateTime>04/01/2016 00:29:19</DateTime>
<DateTimeUTC>1459470559</DateTimeUTC>
<Content>akjdgljsafdlshf;kdsjf</Content>
<ConversationID>PCHAT-0x3000001CA8361</ConversationID>
</Message>
<Message InteractionType="N">
<User>
<LoginName>WVU</LoginName>
<FirstName>WHEELOCK</FirstName>
<LastName>VU</LastName>
<UUID>8266852</UUID>
<FirmNumber>13133</FirmNumber>
<AccountNumber>91189</AccountNumber>
<CompanyName>DBS BANK (HONG KONG)</CompanyName>
<EmailAddress>WVU@Bloomberg.net</EmailAddress>
<CorporateEmailAddress>WHEELOCKVU@DBS.COM</CorporateEmailAddress>
</User>
<DateTime>04/01/2016 00:39:32</DateTime>
<DateTimeUTC>1459471172</DateTimeUTC>
<Content>sagdksajdlsahd</Content>
<ConversationID>PCHAT-0x3000001CA8361</ConversationID>
</Message>
<ParticipantEntered InteractionType="N" DeviceType="M">
<User>
<LoginName>SWONG00</LoginName>
<FirstName>STEPHEN</FirstName>
<LastName>WONG</LastName>
<UUID>4397109</UUID>
<FirmNumber>13133</FirmNumber>
<AccountNumber>231115</AccountNumber>
<CompanyName>DBS BANK LIMITED HON</CompanyName>
<EmailAddress>SWONG00@Bloomberg.net</EmailAddress>
<CorporateEmailAddress>STEPHENWONGWE@DBS.COM</CorporateEmailAddress>
</User>
<DateTime>04/01/2016 01:01:27</DateTime>
<DateTimeUTC>1459472487</DateTimeUTC>
<ConversationID>PCHAT-0x3000001CA8361</ConversationID>
</ParticipantEntered>
<Message InteractionType="N">
<User>
<LoginName>SWONG00</LoginName>
<FirstName>STEPHEN</FirstName>
<LastName>WONG</LastName>
<UUID>4397109</UUID>
<FirmNumber>13133</FirmNumber>
<AccountNumber>231115</AccountNumber>
<CompanyName>DBS BANK LIMITED HON</CompanyName>
<EmailAddress>SWONG00@Bloomberg.net</EmailAddress>
<CorporateEmailAddress>STEPHENWONGWE@DBS.COM</CorporateEmailAddress>
</User>
<DateTime>04/01/2016 01:31:29</DateTime>
<DateTimeUTC>1459474289</DateTimeUTC>
<Content>ajdslsahdsj;a</Content>
<ConversationID>PCHAT-0x3000001CA8361</ConversationID>
</Message>
<Message InteractionType="N" DeviceType="M">
<User>
<LoginName>FCHAN95</LoginName>
<FirstName>FLORENCE</FirstName>
<LastName>CHAN</LastName>
<CompanyName>GOLDMAN SACHS (ASIA)</CompanyName>
<EmailAddress>FCHAN95@Bloomberg.net</EmailAddress>
<CorporateEmailAddress />
</User>
<DateTime>04/01/2016 02:49:46</DateTime>
<DateTimeUTC>1459478986</DateTimeUTC>
<Content>sagdkjsagdkjashdlasjd</Content>
<ConversationID>PCHAT-0x3000001CA8361</ConversationID>
</Message>
<Message InteractionType="N" DeviceType="M">
<User>
<LoginName>FCHAN95</LoginName>
<FirstName>FLORENCE</FirstName>
<LastName>CHAN</LastName>
<CompanyName>GOLDMAN SACHS (ASIA)</CompanyName>
<EmailAddress>FCHAN95@Bloomberg.net</EmailAddress>
<CorporateEmailAddress />
</User>
<DateTime>04/01/2016 02:49:46</DateTime>
<DateTimeUTC>1459478986</DateTimeUTC>
<Content>jsdhkshdksjdlsjdlks</Content>
<ConversationID>PCHAT-0x3000001CA8361</ConversationID>
</Message>
<Message InteractionType="N" DeviceType="M">
<User>
<LoginName>FCHAN95</LoginName>
<FirstName>FLORENCE</FirstName>
<LastName>CHAN</LastName>
<CompanyName>GOLDMAN SACHS (ASIA)</CompanyName>
<EmailAddress>FCHAN95@Bloomberg.net</EmailAddress>
<CorporateEmailAddress />
</User>
<DateTime>04/01/2016 03:47:37</DateTime>
<DateTimeUTC>1459482457</DateTimeUTC>
<Content>jshdkshdksjdlskld</Content>
<ConversationID>PCHAT-0x3000001CA8361</ConversationID>
</Message>
<Message InteractionType="N" DeviceType="M">
<User>
<LoginName>FCHAN95</LoginName>
<FirstName>FLORENCE</FirstName>
<LastName>CHAN</LastName>
<CompanyName>GOLDMAN SACHS (ASIA)</CompanyName>
<EmailAddress>FCHAN95@Bloomberg.net</EmailAddress>
<CorporateEmailAddress />
</User>
<DateTime>04/01/2016 03:47:37</DateTime>
<DateTimeUTC>1459482457</DateTimeUTC>
<Content>aasasasasas</Content>
<ConversationID>PCHAT-0x3000001CA8361</ConversationID>
</Message>
<EndTime>04/01/2016 03:47:37</EndTime>
<EndTimeUTC>1459482457</EndTimeUTC>
</Conversation>
</FileDump>
当前我正在显示用户和内容,但我想打印
userName(CountOfMessages UserSent)+userName(CountOfMessages UserSent)
例如:G_LO(1)+FCHAN95(6)+WVU(1)+SWONG00(1)
我尝试了hashmap
,但它没有像预期的那样工作。Java8特性也不能正常工作。也尝试了multiset
番石榴,但没有用。
您可以使用SAX(注意,不是StAX)非常容易地实现它。您应该也可以使用StAX来完成此操作。当我做的时候我会发布一个更新。SAX上的参考实现如下
import java.io.StringReader;
import java.util.HashMap;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.xml.sax.Attributes;
import org.xml.sax.InputSource;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
public class NumCountHandler extends DefaultHandler {
private HashMap<String, Integer> countOfNum = new HashMap<String, Integer>();
boolean isStartTagPass = false;
@Override
public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {
if (qName.equalsIgnoreCase("LoginName")) {
isStartTagPass = true;
}
}
@Override
public void characters(char[] ch, int start, int length) throws SAXException {
String attributeNum = new String(ch, start, length);
if (isStartTagPass) {
if (countOfNum.containsKey(attributeNum)) {
Integer count = countOfNum.get(attributeNum);
countOfNum.put(attributeNum, new Integer(count.intValue() + 1));
} else {
countOfNum.put(attributeNum, new Integer(1));
}
}
}
@Override
public void endElement(String uri, String localName, String qName) throws SAXException {
if (qName.equalsIgnoreCase("LoginName")) {
isStartTagPass = false;
}
}
public static void main(String[] args) {
try {
String xml = "<FileDump> <Version>IBXML 1.3</Version> <Conversation Perspective=\" \" RoomType=\"P\"> <RoomID>PCHAT-0x3000001CA8361</RoomID> <StartTime>03/31/2016 13:39:01</StartTime> <StartTimeUTC>1459431541</StartTimeUTC> <ParticipantEntered InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>SWONG00</LoginName><FirstName>STEPHEN</FirstName><LastName>WONG</LastName><UUID>4397109</UUID><FirmNumber>13133</FirmNumber><AccountNumber>231115</AccountNumber><CompanyName>DBS BANK LIMITED HON</CompanyName><EmailAddress>SWONG00@Bloomberg.net</EmailAddress><CorporateEmailAddress>STEPHENWONGWE@DBS.COM</CorporateEmailAddress> </User> <DateTime>03/31/2016 13:39:01</DateTime> <DateTimeUTC>1459431541</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantEntered> <ParticipantEntered InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>G_LO</LoginName><FirstName>GARY</FirstName><LastName>LO</LastName><UUID>7054548</UUID><FirmNumber>13133</FirmNumber><AccountNumber>91189</AccountNumber><CompanyName>DBS BANK (HONG KONG)</CompanyName><EmailAddress>G_LO@Bloomberg.net</EmailAddress><CorporateEmailAddress>garyloyc@dbs.com</CorporateEmailAddress> </User> <DateTime>03/31/2016 14:56:22</DateTime> <DateTimeUTC>1459436182</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantEntered> <ParticipantLeft InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>G_LO</LoginName><FirstName>GARY</FirstName><LastName>LO</LastName><UUID>7054548</UUID><FirmNumber>13133</FirmNumber><AccountNumber>91189</AccountNumber><CompanyName>DBS BANK (HONG KONG)</CompanyName><EmailAddress>G_LO@Bloomberg.net</EmailAddress><CorporateEmailAddress>garyloyc@dbs.com</CorporateEmailAddress> </User> <DateTime>03/31/2016 19:30:01</DateTime> <DateTimeUTC>1459452601</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantLeft> <ParticipantLeft InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>SWONG00</LoginName><FirstName>STEPHEN</FirstName><LastName>WONG</LastName><UUID>4397109</UUID><FirmNumber>13133</FirmNumber><AccountNumber>231115</AccountNumber><CompanyName>DBS BANK LIMITED HON</CompanyName><EmailAddress>SWONG00@Bloomberg.net</EmailAddress><CorporateEmailAddress>STEPHENWONGWE@DBS.COM</CorporateEmailAddress> </User> <DateTime>03/31/2016 19:33:56</DateTime> <DateTimeUTC>1459452836</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantLeft> <ParticipantEntered InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>SWONG00</LoginName><FirstName>STEPHEN</FirstName><LastName>WONG</LastName><UUID>4397109</UUID><FirmNumber>13133</FirmNumber><AccountNumber>231115</AccountNumber><CompanyName>DBS BANK LIMITED HON</CompanyName><EmailAddress>SWONG00@Bloomberg.net</EmailAddress><CorporateEmailAddress>STEPHENWONGWE@DBS.COM</CorporateEmailAddress> </User> <DateTime>03/31/2016 19:45:16</DateTime> <DateTimeUTC>1459453516</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantEntered> <ParticipantLeft InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>SWONG00</LoginName><FirstName>STEPHEN</FirstName><LastName>WONG</LastName><UUID>4397109</UUID><FirmNumber>13133</FirmNumber><AccountNumber>231115</AccountNumber><CompanyName>DBS BANK LIMITED HON</CompanyName><EmailAddress>SWONG00@Bloomberg.net</EmailAddress><CorporateEmailAddress>STEPHENWONGWE@DBS.COM</CorporateEmailAddress> </User> <DateTime>03/31/2016 23:08:09</DateTime> <DateTimeUTC>1459465689</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantLeft> <ParticipantEntered InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>G_LO</LoginName><FirstName>GARY</FirstName><LastName>LO</LastName><UUID>7054548</UUID><FirmNumber>13133</FirmNumber><AccountNumber>91189</AccountNumber><CompanyName>DBS BANK (HONG KONG)</CompanyName><EmailAddress>G_LO@Bloomberg.net</EmailAddress><CorporateEmailAddress>garyloyc@dbs.com</CorporateEmailAddress> </User> <DateTime>03/31/2016 23:14:23</DateTime> <DateTimeUTC>1459466063</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantEntered> <Message InteractionType=\"N\"> <User><LoginName>G_LO</LoginName><FirstName>GARY</FirstName><LastName>LO</LastName><UUID>7054548</UUID><FirmNumber>13133</FirmNumber><AccountNumber>91189</AccountNumber><CompanyName>DBS BANK (HONG KONG)</CompanyName><EmailAddress>G_LO@Bloomberg.net</EmailAddress><CorporateEmailAddress>garyloyc@dbs.com</CorporateEmailAddress> </User> <DateTime>04/01/2016 00:10:57</DateTime> <DateTimeUTC>1459469457</DateTimeUTC> <Content>abcdefgghhhhhh</Content> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </Message> <ParticipantEntered InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>WVU</LoginName><FirstName>WHEELOCK</FirstName><LastName>VU</LastName><UUID>8266852</UUID><FirmNumber>13133</FirmNumber><AccountNumber>91189</AccountNumber><CompanyName>DBS BANK (HONG KONG)</CompanyName><EmailAddress>WVU@Bloomberg.net</EmailAddress><CorporateEmailAddress>WHEELOCKVU@DBS.COM</CorporateEmailAddress> </User> <DateTime>04/01/2016 00:14:05</DateTime> <DateTimeUTC>1459469645</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantEntered> <ParticipantEntered InteractionType=\"N\"> <User><LoginName>FCHAN95</LoginName><FirstName>FLORENCE</FirstName><LastName>CHAN</LastName><CompanyName>GOLDMAN SACHS (ASIA)</CompanyName><EmailAddress>FCHAN95@Bloomberg.net</EmailAddress><CorporateEmailAddress /> </User> <DateTime>04/01/2016 00:29:19</DateTime> <DateTimeUTC>1459470559</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantEntered> <Message InteractionType=\"N\"> <User><LoginName>FCHAN95</LoginName><FirstName>FLORENCE</FirstName><LastName>CHAN</LastName><CompanyName>GOLDMAN SACHS (ASIA)</CompanyName><EmailAddress>FCHAN95@Bloomberg.net</EmailAddress><CorporateEmailAddress /> </User> <DateTime>04/01/2016 00:29:19</DateTime> <DateTimeUTC>1459470559</DateTimeUTC> <Content>ajdakjgdljsgdsafhkafa</Content> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </Message> <Message InteractionType=\"N\"> <User><LoginName>FCHAN95</LoginName><FirstName>FLORENCE</FirstName><LastName>CHAN</LastName><CompanyName>GOLDMAN SACHS (ASIA)</CompanyName><EmailAddress>FCHAN95@Bloomberg.net</EmailAddress><CorporateEmailAddress /> </User> <DateTime>04/01/2016 00:29:19</DateTime> <DateTimeUTC>1459470559</DateTimeUTC> <Content>akjdgljsafdlshf;kdsjf</Content> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </Message> <Message InteractionType=\"N\"> <User><LoginName>WVU</LoginName><FirstName>WHEELOCK</FirstName><LastName>VU</LastName><UUID>8266852</UUID><FirmNumber>13133</FirmNumber><AccountNumber>91189</AccountNumber><CompanyName>DBS BANK (HONG KONG)</CompanyName><EmailAddress>WVU@Bloomberg.net</EmailAddress><CorporateEmailAddress>WHEELOCKVU@DBS.COM</CorporateEmailAddress> </User> <DateTime>04/01/2016 00:39:32</DateTime> <DateTimeUTC>1459471172</DateTimeUTC> <Content>sagdksajdlsahd</Content> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </Message> <ParticipantEntered InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>SWONG00</LoginName><FirstName>STEPHEN</FirstName><LastName>WONG</LastName><UUID>4397109</UUID><FirmNumber>13133</FirmNumber><AccountNumber>231115</AccountNumber><CompanyName>DBS BANK LIMITED HON</CompanyName><EmailAddress>SWONG00@Bloomberg.net</EmailAddress><CorporateEmailAddress>STEPHENWONGWE@DBS.COM</CorporateEmailAddress> </User> <DateTime>04/01/2016 01:01:27</DateTime> <DateTimeUTC>1459472487</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantEntered> <Message InteractionType=\"N\"> <User><LoginName>SWONG00</LoginName><FirstName>STEPHEN</FirstName><LastName>WONG</LastName><UUID>4397109</UUID><FirmNumber>13133</FirmNumber><AccountNumber>231115</AccountNumber><CompanyName>DBS BANK LIMITED HON</CompanyName><EmailAddress>SWONG00@Bloomberg.net</EmailAddress><CorporateEmailAddress>STEPHENWONGWE@DBS.COM</CorporateEmailAddress> </User> <DateTime>04/01/2016 01:31:29</DateTime> <DateTimeUTC>1459474289</DateTimeUTC> <Content>ajdslsahdsj;a</Content> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </Message> <Message InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>FCHAN95</LoginName><FirstName>FLORENCE</FirstName><LastName>CHAN</LastName><CompanyName>GOLDMAN SACHS (ASIA)</CompanyName><EmailAddress>FCHAN95@Bloomberg.net</EmailAddress><CorporateEmailAddress /> </User> <DateTime>04/01/2016 02:49:46</DateTime> <DateTimeUTC>1459478986</DateTimeUTC> <Content>sagdkjsagdkjashdlasjd</Content> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </Message> <Message InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>FCHAN95</LoginName><FirstName>FLORENCE</FirstName><LastName>CHAN</LastName><CompanyName>GOLDMAN SACHS (ASIA)</CompanyName><EmailAddress>FCHAN95@Bloomberg.net</EmailAddress><CorporateEmailAddress /> </User> <DateTime>04/01/2016 02:49:46</DateTime> <DateTimeUTC>1459478986</DateTimeUTC> <Content>jsdhkshdksjdlsjdlks</Content> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </Message> <Message InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>FCHAN95</LoginName><FirstName>FLORENCE</FirstName><LastName>CHAN</LastName><CompanyName>GOLDMAN SACHS (ASIA)</CompanyName><EmailAddress>FCHAN95@Bloomberg.net</EmailAddress><CorporateEmailAddress /> </User> <DateTime>04/01/2016 03:47:37</DateTime> <DateTimeUTC>1459482457</DateTimeUTC> <Content>jshdkshdksjdlskld</Content> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </Message> <Message InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>FCHAN95</LoginName><FirstName>FLORENCE</FirstName><LastName>CHAN</LastName><CompanyName>GOLDMAN SACHS (ASIA)</CompanyName><EmailAddress>FCHAN95@Bloomberg.net</EmailAddress><CorporateEmailAddress /> </User> <DateTime>04/01/2016 03:47:37</DateTime> <DateTimeUTC>1459482457</DateTimeUTC> <Content>aasasasasas</Content> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </Message> <EndTime>04/01/2016 03:47:37</EndTime> <EndTimeUTC>1459482457</EndTimeUTC> </Conversation></FileDump>";
;
InputSource is = new InputSource(new StringReader(xml));
SAXParserFactory factory = SAXParserFactory.newInstance();
SAXParser saxParser = factory.newSAXParser();
NumCountHandler userhandler = new NumCountHandler();
saxParser.parse(is, userhandler);
userhandler.countOfNum
.forEach((k, v) -> System.out.print(k +"("+v+") "));
} catch (Exception e) {
e.printStackTrace();
}
}
}
这将显示:wvu(2)+g_lo(4)+fchan95(7)+swong00(6)+
======添加了一个基于StaX的实现===========
可以通过Java8特性进行改进。此外,我已经使用静态变量只是一个小的试点,应该可以做它与类变量,以及一些refractoring
import java.io.StringReader;
import java.util.HashMap;
import javax.xml.stream.XMLEventReader;
import javax.xml.stream.XMLInputFactory;
import javax.xml.stream.events.Characters;
import javax.xml.stream.events.XMLEvent;
public class NumCountHandlerStax {
private boolean isStartTagPass = false;
static private void groupAndProcess(Object object, HashMap<String, Integer> countOfNum,
NumCountHandlerStax staxBasedCounter) {
XMLEvent event = (XMLEvent) object;
if (event.isStartElement() && event.asStartElement().getName().getLocalPart().equals("LoginName")) {
staxBasedCounter.isStartTagPass = true;
} else if (event.isEndElement() && event.asEndElement().getName().getLocalPart().equals("LoginName")) {
staxBasedCounter.isStartTagPass = false;
} else if (staxBasedCounter.isStartTagPass && event.isCharacters()) {
Characters characters = event.asCharacters();
String attributeNum = characters.getData();
if (countOfNum.containsKey(attributeNum)) {
Integer count = countOfNum.get(attributeNum);
countOfNum.put(attributeNum, new Integer(count.intValue() + 1));
} else {
countOfNum.put(attributeNum, new Integer(1));
}
}
}
public static void main(String[] args) {
try {
NumCountHandlerStax staxBasedCounter = new NumCountHandlerStax();
HashMap<String, Integer> countOfNum = new HashMap<String, Integer>();
String xml = "<FileDump> <Version>IBXML 1.3</Version> <Conversation Perspective=\" \" RoomType=\"P\"> <RoomID>PCHAT-0x3000001CA8361</RoomID> <StartTime>03/31/2016 13:39:01</StartTime> <StartTimeUTC>1459431541</StartTimeUTC> <ParticipantEntered InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>SWONG00</LoginName><FirstName>STEPHEN</FirstName><LastName>WONG</LastName><UUID>4397109</UUID><FirmNumber>13133</FirmNumber><AccountNumber>231115</AccountNumber><CompanyName>DBS BANK LIMITED HON</CompanyName><EmailAddress>SWONG00@Bloomberg.net</EmailAddress><CorporateEmailAddress>STEPHENWONGWE@DBS.COM</CorporateEmailAddress> </User> <DateTime>03/31/2016 13:39:01</DateTime> <DateTimeUTC>1459431541</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantEntered> <ParticipantEntered InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>G_LO</LoginName><FirstName>GARY</FirstName><LastName>LO</LastName><UUID>7054548</UUID><FirmNumber>13133</FirmNumber><AccountNumber>91189</AccountNumber><CompanyName>DBS BANK (HONG KONG)</CompanyName><EmailAddress>G_LO@Bloomberg.net</EmailAddress><CorporateEmailAddress>garyloyc@dbs.com</CorporateEmailAddress> </User> <DateTime>03/31/2016 14:56:22</DateTime> <DateTimeUTC>1459436182</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantEntered> <ParticipantLeft InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>G_LO</LoginName><FirstName>GARY</FirstName><LastName>LO</LastName><UUID>7054548</UUID><FirmNumber>13133</FirmNumber><AccountNumber>91189</AccountNumber><CompanyName>DBS BANK (HONG KONG)</CompanyName><EmailAddress>G_LO@Bloomberg.net</EmailAddress><CorporateEmailAddress>garyloyc@dbs.com</CorporateEmailAddress> </User> <DateTime>03/31/2016 19:30:01</DateTime> <DateTimeUTC>1459452601</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantLeft> <ParticipantLeft InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>SWONG00</LoginName><FirstName>STEPHEN</FirstName><LastName>WONG</LastName><UUID>4397109</UUID><FirmNumber>13133</FirmNumber><AccountNumber>231115</AccountNumber><CompanyName>DBS BANK LIMITED HON</CompanyName><EmailAddress>SWONG00@Bloomberg.net</EmailAddress><CorporateEmailAddress>STEPHENWONGWE@DBS.COM</CorporateEmailAddress> </User> <DateTime>03/31/2016 19:33:56</DateTime> <DateTimeUTC>1459452836</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantLeft> <ParticipantEntered InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>SWONG00</LoginName><FirstName>STEPHEN</FirstName><LastName>WONG</LastName><UUID>4397109</UUID><FirmNumber>13133</FirmNumber><AccountNumber>231115</AccountNumber><CompanyName>DBS BANK LIMITED HON</CompanyName><EmailAddress>SWONG00@Bloomberg.net</EmailAddress><CorporateEmailAddress>STEPHENWONGWE@DBS.COM</CorporateEmailAddress> </User> <DateTime>03/31/2016 19:45:16</DateTime> <DateTimeUTC>1459453516</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantEntered> <ParticipantLeft InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>SWONG00</LoginName><FirstName>STEPHEN</FirstName><LastName>WONG</LastName><UUID>4397109</UUID><FirmNumber>13133</FirmNumber><AccountNumber>231115</AccountNumber><CompanyName>DBS BANK LIMITED HON</CompanyName><EmailAddress>SWONG00@Bloomberg.net</EmailAddress><CorporateEmailAddress>STEPHENWONGWE@DBS.COM</CorporateEmailAddress> </User> <DateTime>03/31/2016 23:08:09</DateTime> <DateTimeUTC>1459465689</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantLeft> <ParticipantEntered InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>G_LO</LoginName><FirstName>GARY</FirstName><LastName>LO</LastName><UUID>7054548</UUID><FirmNumber>13133</FirmNumber><AccountNumber>91189</AccountNumber><CompanyName>DBS BANK (HONG KONG)</CompanyName><EmailAddress>G_LO@Bloomberg.net</EmailAddress><CorporateEmailAddress>garyloyc@dbs.com</CorporateEmailAddress> </User> <DateTime>03/31/2016 23:14:23</DateTime> <DateTimeUTC>1459466063</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantEntered> <Message InteractionType=\"N\"> <User><LoginName>G_LO</LoginName><FirstName>GARY</FirstName><LastName>LO</LastName><UUID>7054548</UUID><FirmNumber>13133</FirmNumber><AccountNumber>91189</AccountNumber><CompanyName>DBS BANK (HONG KONG)</CompanyName><EmailAddress>G_LO@Bloomberg.net</EmailAddress><CorporateEmailAddress>garyloyc@dbs.com</CorporateEmailAddress> </User> <DateTime>04/01/2016 00:10:57</DateTime> <DateTimeUTC>1459469457</DateTimeUTC> <Content>abcdefgghhhhhh</Content> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </Message> <ParticipantEntered InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>WVU</LoginName><FirstName>WHEELOCK</FirstName><LastName>VU</LastName><UUID>8266852</UUID><FirmNumber>13133</FirmNumber><AccountNumber>91189</AccountNumber><CompanyName>DBS BANK (HONG KONG)</CompanyName><EmailAddress>WVU@Bloomberg.net</EmailAddress><CorporateEmailAddress>WHEELOCKVU@DBS.COM</CorporateEmailAddress> </User> <DateTime>04/01/2016 00:14:05</DateTime> <DateTimeUTC>1459469645</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantEntered> <ParticipantEntered InteractionType=\"N\"> <User><LoginName>FCHAN95</LoginName><FirstName>FLORENCE</FirstName><LastName>CHAN</LastName><CompanyName>GOLDMAN SACHS (ASIA)</CompanyName><EmailAddress>FCHAN95@Bloomberg.net</EmailAddress><CorporateEmailAddress /> </User> <DateTime>04/01/2016 00:29:19</DateTime> <DateTimeUTC>1459470559</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantEntered> <Message InteractionType=\"N\"> <User><LoginName>FCHAN95</LoginName><FirstName>FLORENCE</FirstName><LastName>CHAN</LastName><CompanyName>GOLDMAN SACHS (ASIA)</CompanyName><EmailAddress>FCHAN95@Bloomberg.net</EmailAddress><CorporateEmailAddress /> </User> <DateTime>04/01/2016 00:29:19</DateTime> <DateTimeUTC>1459470559</DateTimeUTC> <Content>ajdakjgdljsgdsafhkafa</Content> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </Message> <Message InteractionType=\"N\"> <User><LoginName>FCHAN95</LoginName><FirstName>FLORENCE</FirstName><LastName>CHAN</LastName><CompanyName>GOLDMAN SACHS (ASIA)</CompanyName><EmailAddress>FCHAN95@Bloomberg.net</EmailAddress><CorporateEmailAddress /> </User> <DateTime>04/01/2016 00:29:19</DateTime> <DateTimeUTC>1459470559</DateTimeUTC> <Content>akjdgljsafdlshf;kdsjf</Content> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </Message> <Message InteractionType=\"N\"> <User><LoginName>WVU</LoginName><FirstName>WHEELOCK</FirstName><LastName>VU</LastName><UUID>8266852</UUID><FirmNumber>13133</FirmNumber><AccountNumber>91189</AccountNumber><CompanyName>DBS BANK (HONG KONG)</CompanyName><EmailAddress>WVU@Bloomberg.net</EmailAddress><CorporateEmailAddress>WHEELOCKVU@DBS.COM</CorporateEmailAddress> </User> <DateTime>04/01/2016 00:39:32</DateTime> <DateTimeUTC>1459471172</DateTimeUTC> <Content>sagdksajdlsahd</Content> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </Message> <ParticipantEntered InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>SWONG00</LoginName><FirstName>STEPHEN</FirstName><LastName>WONG</LastName><UUID>4397109</UUID><FirmNumber>13133</FirmNumber><AccountNumber>231115</AccountNumber><CompanyName>DBS BANK LIMITED HON</CompanyName><EmailAddress>SWONG00@Bloomberg.net</EmailAddress><CorporateEmailAddress>STEPHENWONGWE@DBS.COM</CorporateEmailAddress> </User> <DateTime>04/01/2016 01:01:27</DateTime> <DateTimeUTC>1459472487</DateTimeUTC> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </ParticipantEntered> <Message InteractionType=\"N\"> <User><LoginName>SWONG00</LoginName><FirstName>STEPHEN</FirstName><LastName>WONG</LastName><UUID>4397109</UUID><FirmNumber>13133</FirmNumber><AccountNumber>231115</AccountNumber><CompanyName>DBS BANK LIMITED HON</CompanyName><EmailAddress>SWONG00@Bloomberg.net</EmailAddress><CorporateEmailAddress>STEPHENWONGWE@DBS.COM</CorporateEmailAddress> </User> <DateTime>04/01/2016 01:31:29</DateTime> <DateTimeUTC>1459474289</DateTimeUTC> <Content>ajdslsahdsj;a</Content> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </Message> <Message InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>FCHAN95</LoginName><FirstName>FLORENCE</FirstName><LastName>CHAN</LastName><CompanyName>GOLDMAN SACHS (ASIA)</CompanyName><EmailAddress>FCHAN95@Bloomberg.net</EmailAddress><CorporateEmailAddress /> </User> <DateTime>04/01/2016 02:49:46</DateTime> <DateTimeUTC>1459478986</DateTimeUTC> <Content>sagdkjsagdkjashdlasjd</Content> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </Message> <Message InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>FCHAN95</LoginName><FirstName>FLORENCE</FirstName><LastName>CHAN</LastName><CompanyName>GOLDMAN SACHS (ASIA)</CompanyName><EmailAddress>FCHAN95@Bloomberg.net</EmailAddress><CorporateEmailAddress /> </User> <DateTime>04/01/2016 02:49:46</DateTime> <DateTimeUTC>1459478986</DateTimeUTC> <Content>jsdhkshdksjdlsjdlks</Content> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </Message> <Message InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>FCHAN95</LoginName><FirstName>FLORENCE</FirstName><LastName>CHAN</LastName><CompanyName>GOLDMAN SACHS (ASIA)</CompanyName><EmailAddress>FCHAN95@Bloomberg.net</EmailAddress><CorporateEmailAddress /> </User> <DateTime>04/01/2016 03:47:37</DateTime> <DateTimeUTC>1459482457</DateTimeUTC> <Content>jshdkshdksjdlskld</Content> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </Message> <Message InteractionType=\"N\" DeviceType=\"M\"> <User><LoginName>FCHAN95</LoginName><FirstName>FLORENCE</FirstName><LastName>CHAN</LastName><CompanyName>GOLDMAN SACHS (ASIA)</CompanyName><EmailAddress>FCHAN95@Bloomberg.net</EmailAddress><CorporateEmailAddress /> </User> <DateTime>04/01/2016 03:47:37</DateTime> <DateTimeUTC>1459482457</DateTimeUTC> <Content>aasasasasas</Content> <ConversationID>PCHAT-0x3000001CA8361</ConversationID> </Message> <EndTime>04/01/2016 03:47:37</EndTime> <EndTimeUTC>1459482457</EndTimeUTC> </Conversation></FileDump>";
;
XMLInputFactory xmlInputFactory = XMLInputFactory.newInstance();
XMLEventReader xmlEventReader = xmlInputFactory.createXMLEventReader(new StringReader(xml));
xmlEventReader.forEachRemaining(event -> groupAndProcess(event, countOfNum, staxBasedCounter));
countOfNum.forEach((k, v) -> System.out.print(k + "(" + v + ") "));
} catch (Exception e) {
e.printStackTrace();
}
}
}
Prints `WVU(2) G_LO(4) FCHAN95(7) SWONG00(6)`
根据这一点,像XML这样的 但是,将Jackson XmlMapper(默认情况下)用于此类类: 给出一个错误: com.fasterxml.jackson.databind.exc.未识别属性异常:未识别字段""(类org.example.jackson.unwrap.TestIt1$根),未标记为可忽略(一个已知属性:"sub"])... 好的,我可以补充一下 除根文本“asdasda”外,我
我正在阅读XML并解析它,希望更新XML中的所有锚标记:在上面的例子中,我希望在一个标记中附加域名。如果href属性不是以HTTPS、HTTP或www开头。我想将基URL追加到href属性。 怎么做?
我相信一定有一些方法可以指定用来解析XML对象的类,但我无法理解XStream属性的本质或本质。 如有任何帮助,将不胜感激。
我正在尝试解析
问题内容: 这是我的HTML来源 这是我获取内容的Java程序,它过滤HTML标记 是否有使用Jsoup而不是使用Java而不是Regex解析HTML内容的简便方法 有没有办法只获取所需的内容。所以在这里我只需要内容“项目2-222” 问题答案: 尝试使用jsoup轻松解析: 要了解更多信息,请访问Jsoup Docs
我陷入了一个棘手的问题,我应该使用JAXB库取消marshaX输入流,除了XML结构没有帮助。 我的问题是:标记用于值为>的的