gpt4 book ai didi

java - Java中高效的字符串读取?

转载 作者:行者123 更新时间:2023-12-01 14:24:55 25 4
gpt4 key购买 nike

我收到一个数据包,例如

“c~ 1”M:0013A20040559361 Ax:48 Ay:10 Az:1012 Tp:25 B:45?时间:星期三,02/01/13 - 16:16.57 S°~"

其他无法粘贴的字符。我必须读取冒号后面的值。例如,M:、Ax:、Ay: 并将其存储或绘制在图表中。我知道两种方法:StreamTokenizer 或简单的java 逻辑。问题是我已经尝试了这两种方法,但在读取值时仍然收到太多错误。另外,我尝试了字符串垃圾收集器,它也不起作用。

下面是两者的代码:

if(message2.contains("Ax:"))
{
int index = message2.indexOf("Ax:");
String Ax = message2.substring(index+3);
ChartAcceleration.tsAx.addOrUpdate(new Millisecond(), Double.valueOf(Ax));
}

StreamTokenizer Code:

StreamTokenizer st = new StreamTokenizer(
new StringReader(message));

boolean eof = false;
while(st.nextToken() != StreamTokenizer.TT_EOF){

int token = st.nextToken();
switch (token) {
case StreamTokenizer.TT_WORD:
String word = st.sval;
if(word.contains("Ax"))
{
Ax = true;
}
else
if(word.contains("Ay"))
{
Ay = true;
}
else
if(word.contains("Az"))
{
Az = true;
}
else
if(word.contains("P"))
{
P = true;

}
else
if(word.contains("B"))
{
B = true;
}
else
if(word.contains("Tp"))
{
Tp = true;
}
else
{
Ax = false;
Ay = false;
Az = false;
P = false;
B = false;
Tp = false;
}
// System.out.println("Word: " + word);
break;
case StreamTokenizer.TT_NUMBER:
double number = st.nval;
if(Ax)
{
Ax = false;
// errorChecker(AxStr,number);
AxStr = number;
Sender.publishAccelerator("Ax:" + String.valueOf(AxStr));
}
else
if(Ay)
{
Ay = false;
AyStr = number;
Sender.publishAccelerator("Ay:"+String.valueOf(AyStr));
}
else if(Az)
{
Az = false;
AzStr = number;
Sender.publishAccelerator("Az:"+String.valueOf(AzStr));
// System.out.println("Az:"+AzStr);

}
else
if(P)
{
P = false;
PStr = number;
Sender.publishPressure(String.valueOf(PStr));
//System.out.println("P:"+PStr);

}
else
if(B)
{
B = false;
BStr = number;
Sender.publishBattery(String.valueOf(BStr));
}
else
if(Tp)
{
Tp = false;
TpStr = number;
Sender.publishTemp(String.valueOf(TpStr));
}
break;

default:
}
}

最佳答案

我为您的文本编写了一个字符串解析程序。

您定义要解析的标记和结束标记。

这是我的结果。

Ay: 10
Az: 1012
Tp: 25
B: 45
Ax: 48
Tm: Wednesday, 02/01/13 - 16:16.57

这是解析代码。

import java.util.Iterator;
import java.util.Properties;
import java.util.Set;

public class StringParsing {

private String[][] tokens = { {"Ax:", " "},
{"Ay:", " "}, {"Az:", " "}, {"Tp:", " "}, {"B:", " "},
{"Tm:", " Sº"} };

public Properties parseString(String s) {
Properties p = new Properties();

for (int i = 0; i < tokens.length; i++) {
String value = getValue(s, tokens[i][0], tokens[i][1]);
p.setProperty(tokens[i][0], value);
}
return p;
}

private String getValue(String s, String token, String endToken) {
int sPos = s.indexOf(token);
if (sPos >= 0) {
int ePos = s.indexOf(endToken, sPos + 1);
if (ePos > sPos) {
sPos += token.length();
return s.substring(sPos, ePos);
}
}
return "";
}


public static void main(String[] args) {
String s = "c~ ¹\" M:0013A20040559361 Ax:48 Ay:10 Az:1012 " +
"Tp:25 B:45 ? Tm:Wednesday, 02/01/13 - 16:16.57 Sº~";

StringParsing parsing = new StringParsing();
Properties p = parsing.parseString(s);

Set<Object> keys = p.keySet();
Iterator<Object> iter = keys.iterator();

while(iter.hasNext()) {
String key = (String) iter.next();
String value = p.getProperty(key);
System.out.println(key + " " + value);
}
}

}

已编辑以添加代码以响应评论。

我还没有对此进行测试,因为我没有您的数据文件,但这是加载 map 的方法。重要的是,您必须为每个 Map 条目创建一个新的 Properties 对象,因为映射包含一个指向 Properties 对象的指针。

   public void processStrings() {
Map<String, Properties> dataMap = new TreeMap<String, Properties>();
StringParsing parsing = new StringParsing();
try {
BufferedReader reader = new BufferedReader(new FileReader(
"dataFile.txt"));
String line = "";
while ((line = reader.readLine()) != null) {
Properties p = parsing.parseString(line);
dataMap.put(p.getProperty("M:"), p);
}
reader.close();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}

关于java - Java中高效的字符串读取?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17229651/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com