- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我手头的任务是能够根据地址中的文本文件处理行,并将它们分类到各自的类别中,“东”、“西”、“百老汇”、“大道”和“坏 ID” 。下面的代码可以 100% 正确地执行此操作,直到遇到包含双逗号的格式错误的行,而我可以用单逗号替换所有双逗号,但这并不能完全解决问题,因为该行将被视为“格式错误”并且然后应该添加到 badId 的类别中,但它会导致 NumberFormatException
完全错误和下面的代码。我想知道是否有可能以一种不会导致此异常的方式忽略双逗号,但仍然能够解析文件的其余部分,并按预期将此行添加到 badId 的数组中。
读取文本文件
123-ABC-4567, 15 W. 15th St., 50.1
456-BGT-9876,22 Broadway,24
QAZ-456-QWER, 100 East 20th Street,50
Q2Z-457-QWER, 200 East 20th Street, 49
678-FGH-9845 ,,45 5th Ave, 12.2,
678-FGH-9846 ,45 5th Ave, 12.2
123-ABC-9999, 46 Foo Bar, 220.0
347-poy-3465, 101 B'way,24
错误
java.lang.NumberFormatException: For input string: "45 5th Ave"
at sun.misc.FloatingDecimal.readJavaFormatString(Unknown Source)
at sun.misc.FloatingDecimal.parseFloat(Unknown Source)
at java.lang.Float.parseFloat(Unknown Source)
at java.lang.Float.valueOf(Unknown Source)
at csi311.HelloCsi311.readFile(HelloCsi311.java:99)
at csi311.HelloCsi311.run(HelloCsi311.java:28)
at csi311.HelloCsi311.main(HelloCsi311.java:240)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at edu.rice.cs.drjava.model.compiler.JavacCompiler.runCommand(JavacCompiler.java:267)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at edu.rice.cs.dynamicjava.symbol.JavaClass$JavaMethod.evaluate(JavaClass.java:362)
at edu.rice.cs.dynamicjava.interpreter.ExpressionEvaluator.handleMethodCall(ExpressionEvaluator.java:92)
at edu.rice.cs.dynamicjava.interpreter.ExpressionEvaluator.visit(ExpressionEvaluator.java:84)
at koala.dynamicjava.tree.StaticMethodCall.acceptVisitor(StaticMethodCall.java:121)
at edu.rice.cs.dynamicjava.interpreter.ExpressionEvaluator.value(ExpressionEvaluator.java:38)
at edu.rice.cs.dynamicjava.interpreter.ExpressionEvaluator.value(ExpressionEvaluator.java:37)
at edu.rice.cs.dynamicjava.interpreter.StatementEvaluator.visit(StatementEvaluator.java:106)
at edu.rice.cs.dynamicjava.interpreter.StatementEvaluator.visit(StatementEvaluator.java:29)
at koala.dynamicjava.tree.ExpressionStatement.acceptVisitor(ExpressionStatement.java:101)
at edu.rice.cs.dynamicjava.interpreter.StatementEvaluator.evaluateSequence(StatementEvaluator.java:66)
at edu.rice.cs.dynamicjava.interpreter.Interpreter.evaluate(Interpreter.java:77)
at edu.rice.cs.dynamicjava.interpreter.Interpreter.interpret(Interpreter.java:47)
at edu.rice.cs.drjava.model.repl.newjvm.InterpreterJVM.interpret(InterpreterJVM.java:249)
at edu.rice.cs.drjava.model.repl.newjvm.InterpreterJVM.interpret(InterpreterJVM.java:222)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at sun.rmi.server.UnicastServerRef.dispatch(Unknown Source)
at sun.rmi.transport.Transport$1.run(Unknown Source)
at sun.rmi.transport.Transport$1.run(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at sun.rmi.transport.Transport.serviceCall(Unknown Source)
at sun.rmi.transport.tcp.TCPTransport.handleMessages(Unknown Source)
at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(Unknown Source)
at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at java.lang.Thread.run(Unknown Source)
代码
import java.io.BufferedReader;
import java.io.FileReader;
import java.util.regex.Pattern;
import java.util.regex.Matcher;
import java.util.ArrayList;
/**
* Hello world example. Shows passing in command line arguments, in this case a filename.
* If the filename is given, read in the file and echo it to stdout.
*/
public class HelloCsi311 {
/**
* Class construtor.
*/
public HelloCsi311() {
}
/**
* @param filename the name of a file to read in
* @throws Exception on anything bad happening
*/
public void run(String filename) throws Exception {
if (filename != null) {
readFile(filename);
}
}
/**
* @param filename the name of a file to read in
* @throws Exception on anything bad happening
*/
private void readFile(String filename) throws Exception {
System.out.println("Processing file: " + filename);
// Open the file and connect it to a buffered reader.
BufferedReader br = new BufferedReader(new FileReader(filename));
ArrayList<String> foundaddr = new ArrayList<String>();
ArrayList<String> broadway = new ArrayList<String>();
ArrayList<String> ave = new ArrayList<String>();
ArrayList<String> east = new ArrayList<String>();
ArrayList<String> west = new ArrayList<String>();
ArrayList<String> overlb = new ArrayList<String>();
ArrayList<String> badId = new ArrayList<String>();
String line = null;
String pattern = "^\\d\\d\\d-[A-Za-z][A-Za-z][A-Za-z]-\\d\\d\\d\\d";
String west1 = "^\\d{1,4}\\s\\b(West|west)\\b\\s\\d{1,3}\\w+\\s\\b(St|st)\\B";
String west2 = "^\\d{1,4}\\s\\b(W|w)\\.\\s\\d{1,3}\\w+\\s\\b(St|st)\\.";
String west3 = "^\\d{1,4}\\s\\b(W|w)\\s\\d{1,3}\\w+\\s\\b(St|st)";
String east1 = "^\\d{1,4}\\s\\b(East|east)\\b\\s\\d{1,3}\\w+\\s\\b(St|st)\\B";
String east2 = "^\\d{1,4}\\s\\b(E|e)\\.\\s\\d{1,3}\\w+\\s\\b(St|st)";
String east3 = "^\\d{1,4}\\s\\b(E|e)\\s\\d{1,3}\\w+\\s\\b(St|st)";
String broad1 = "^\\d{1,4}\\s\\b(B|b)\\B(Way|way)";
String broad2 = "^\\d{1,4}\\s\\b(B|b)\\b(.|')(Way|way)";
String broad3 = "^\\d{1,4}\\s\\b(Broadway|broadway)";
String avenue1 = "^\\d{1,4}\\s\\w+\\s\\b(Ave|ave)";
String avenue2 = "^\\d{1,4}\\s\\w+\\s\\b(Ave.|ave.)";
String avenue3 = "^\\d{1,4}\\s\\w+\\s\\b(Avenue|avenue)";
Pattern r = Pattern.compile(pattern);
Pattern z = Pattern.compile(east1);
Pattern zz = Pattern.compile(east2);
Pattern zzz = Pattern.compile(east3);
Pattern we = Pattern.compile(west1);
Pattern wee = Pattern.compile(west2);
Pattern weee = Pattern.compile(west3);
Pattern broadc = Pattern.compile(broad1);
Pattern broadcc = Pattern.compile(broad2);
Pattern broadccc = Pattern.compile(broad3);
Pattern avec = Pattern.compile(avenue1);
Pattern avecc = Pattern.compile(avenue2);
Pattern aveccc = Pattern.compile(avenue3);
// Get lines from the file one at a time until there are no more.
while ((line = br.readLine()) != null) {
if(line.trim().isEmpty()) {
continue;
}
String sample = line.replaceAll("\\s+,", ",").replaceAll(",+\\s",",");
String[] result = sample.split(",");
String pkgId = result[0].trim().toUpperCase();
String pkgAddr = result[1].trim();
// System.out.println(sample);
//System.out.println(pkgId);
//System.out.println(pkgAddr);
Matcher easts = z.matcher(pkgAddr);
Matcher eastss = zz.matcher(pkgAddr);
Matcher eastsss = zzz.matcher(pkgAddr);
Matcher wests = we.matcher(pkgAddr);
Matcher westss = wee.matcher(pkgAddr);
Matcher westsss = weee.matcher(pkgAddr);
Matcher broadways = broadc.matcher(pkgAddr);
Matcher broadwayss = broadcc.matcher(pkgAddr);
Matcher broadwaysss = broadccc.matcher(pkgAddr);
Matcher avenues = avec.matcher(pkgAddr);
Matcher avenuess = avecc.matcher(pkgAddr);
Matcher avenuesss = aveccc.matcher(pkgAddr);
Float f = Float.valueOf(result[2]);
for(String str : result){
//System.out.println(str);
// Trying to match for different types
Matcher m = r.matcher(str);
// REMEMBER TO ADD BROADWAYS AND AVENUES HERE TOO AND FIX SO IT DOESNT HAVE ALL THE IDS
if (!pkgId.matches(pattern) || !pkgAddr.matches(west1) && !pkgAddr.matches(west2) && !pkgAddr.matches(west3)
&& !pkgAddr.matches(east1) && !pkgAddr.matches(east2) && !pkgAddr.matches(east3) && !pkgAddr.matches(broad1)
&& !pkgAddr.matches(broad2) && !pkgAddr.matches(broad3) && !pkgAddr.matches(avenue1) && !pkgAddr.matches(avenue2)
&& !pkgAddr.matches(avenue3)) {
if(!badId.contains(pkgId)){
badId.add(pkgId);
}
//System.out.println(pkgId);
}
if(f < 50){
//System.out.println(str);
if(m.find()) {
//System.out.println(str);
//System.out.println(pkgAddr);
if(avenues.find() || avenuess.find() || avenuesss.find()){
if(!ave.contains(pkgAddr)){
ave.add(pkgAddr);
}
}
if(broadways.find() || broadwayss.find() || broadwaysss.find()){
if(!broadway.contains(pkgAddr)){
broadway.add(pkgAddr);
}
}
if(easts.find() || eastss.find() || eastsss.find()){
if(!east.contains(pkgAddr)){
east.add(pkgAddr);
}
}
if(wests.find() || westss.find() || westsss.find()){
if(!west.contains(pkgAddr)){
west.add(pkgAddr);
}
}
}
//System.out.println(str);
}
if(f > 50){
if(avenues.find() || avenuesss.find() || avenuesss.find()){
if(!ave.contains(pkgAddr)){
ave.add(pkgAddr);
if(!overlb.contains(pkgId)){
overlb.add(pkgId);
}
}
}
if(broadways.find() || broadwayss.find() || broadwaysss.find()){
if(!broadway.contains(pkgAddr)){
broadway.add(pkgAddr);
if(!overlb.contains(pkgId)){
overlb.add(pkgId);
}
}
}
// System.out.println(str);
if(easts.find() || eastss.find() || eastsss.find()){
if(!east.contains(pkgAddr)){
east.add(pkgAddr);
if(!overlb.contains(pkgId)){
//System.out.println(pkgId);
overlb.add(pkgId);
}
}
}
if(wests.find() || westss.find() || westsss.find()){
if(!west.contains(pkgAddr)){
west.add(pkgAddr);
if(!overlb.contains(pkgId)){
//System.out.println(pkgId);
overlb.add(pkgId);
}
}
}
//System.out.println(str);
}
}
}
if(west != null) {
// System.out.println(east);
System.out.println("West: " + west.size());
}
if(east != null){
// System.out.println(west);
System.out.println("East: " + east.size());
}
if(ave != null){
//System.out.println(ave);
System.out.println("Ave: " + ave.size());
}
if(broadway != null){
//System.out.println(broadway);
System.out.println("Bway: " + broadway.size());
}
if(overlb != null){
// System.out.println(overlb);
System.out.println(">50lbs: " + overlb.size());
}
if(badId != null){
System.out.println("Ids?: " + badId);
}
// Close the buffer and the underlying file.
br.close();
}
/**
* @param args filename
*/
public static void main(String[] args) {
// Make an instance of the class.
HelloCsi311 theApp = new HelloCsi311();
String filename = null;
// If a command line argument was given, use it as the filename.
if (args.length > 0) {
filename = args[0];
}
try {
// Run the run(), passing in the filename, null if not specified.
theApp.run(filename);
}
catch (Exception e) {
// If anything bad happens, report it.
System.out.println("Something bad happened!");
e.printStackTrace();
}
}
}
预期输出
Processing file: test.in
West: 1
East: 0
Ave: 1
Bway: 2
>50lbs: 1
Ids?: [QAZ-456-QWER, Q2Z-457-QWER, 678-FGH-9845, 123-ABC-9999]
最佳答案
这里的问题在于:
Float f = Float.valueOf(result[2]);
这里您尝试将第二个索引的值转换为 Float
.
在前四行数据中,转换没有问题,因为转换的值为 50.1,24,50
。
但是,由于“双逗号”实际上会被解析为空字符串,因此现在的转换改为 45 5th Ave
,然后会抛出 NumberFormatException
.
在有关过滤掉数组中空值的注释中查询后添加了以下部分:
您可以使用以下代码过滤掉数组中的空值(Java 8 及更高版本):
String[] filteredResult = Arrays.stream(result).filter(o -> !o.isEmpty()).toArray(String[]::new);
话虽这么说..此解决方案专门针对您在这种情况下面临的问题,并且可能不是一个好的解决方案。
实际的解决方案是在开始解析数据之前对其进行实际清理。
关于Java 不会因双逗号而崩溃 "malformed line",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54509627/
我正在编写一个具有以下签名的 Java 方法。 void Logger(Method method, Object[] args); 如果一个方法(例如 ABC() )调用此方法 Logger,它应该
我是 Java 新手。 我的问题是我的 Java 程序找不到我试图用作的图像文件一个 JButton。 (目前这段代码什么也没做,因为我只是得到了想要的外观第一的)。这是我的主课 代码: packag
好的,今天我在接受采访,我已经编写 Java 代码多年了。采访中说“Java 垃圾收集是一个棘手的问题,我有几个 friend 一直在努力弄清楚。你在这方面做得怎么样?”。她是想骗我吗?还是我的一生都
我的 friend 给了我一个谜语让我解开。它是这样的: There are 100 people. Each one of them, in his turn, does the following
如果我将使用 Java 5 代码的应用程序编译成字节码,生成的 .class 文件是否能够在 Java 1.4 下运行? 如果后者可以工作并且我正在尝试在我的 Java 1.4 应用程序中使用 Jav
有关于why Java doesn't support unsigned types的问题以及一些关于处理无符号类型的问题。我做了一些搜索,似乎 Scala 也不支持无符号数据类型。限制是Java和S
我只是想知道在一个 java 版本中生成的字节码是否可以在其他 java 版本上运行 最佳答案 通常,字节码无需修改即可在 较新 版本的 Java 上运行。它不会在旧版本上运行,除非您使用特殊参数 (
我有一个关于在命令提示符下执行 java 程序的基本问题。 在某些机器上我们需要指定 -cp 。 (类路径)同时执行java程序 (test为java文件名与.class文件存在于同一目录下) jav
我已经阅读 StackOverflow 有一段时间了,现在我才鼓起勇气提出问题。我今年 20 岁,目前在我的家乡(罗马尼亚克卢日-纳波卡)就读 IT 大学。足以介绍:D。 基本上,我有一家提供簿记应用
我有 public JSONObject parseXML(String xml) { JSONObject jsonObject = XML.toJSONObject(xml); r
我已经在 Java 中实现了带有动态类型的简单解释语言。不幸的是我遇到了以下问题。测试时如下代码: def main() { def ks = Map[[1, 2]].keySet()
一直提示输入 1 到 10 的数字 - 结果应将 st、rd、th 和 nd 添加到数字中。编写一个程序,提示用户输入 1 到 10 之间的任意整数,然后以序数形式显示该整数并附加后缀。 public
我有这个 DownloadFile.java 并按预期下载该文件: import java.io.*; import java.net.URL; public class DownloadFile {
我想在 GUI 上添加延迟。我放置了 2 个 for 循环,然后重新绘制了一个标签,但这 2 个 for 循环一个接一个地执行,并且标签被重新绘制到最后一个。 我能做什么? for(int i=0;
我正在对对象 Student 的列表项进行一些测试,但是我更喜欢在 java 类对象中创建硬编码列表,然后从那里提取数据,而不是连接到数据库并在结果集中选择记录。然而,自从我这样做以来已经很长时间了,
我知道对象创建分为三个部分: 声明 实例化 初始化 classA{} classB extends classA{} classA obj = new classB(1,1); 实例化 它必须使用
我有兴趣使用 GPRS 构建车辆跟踪系统。但是,我有一些问题要问以前做过此操作的人: GPRS 是最好的技术吗?人们意识到任何问题吗? 我计划使用 Java/Java EE - 有更好的技术吗? 如果
我可以通过递归方法反转数组,例如:数组={1,2,3,4,5} 数组结果={5,4,3,2,1}但我的结果是相同的数组,我不知道为什么,请帮助我。 public class Recursion { p
有这样的标准方式吗? 包括 Java源代码-测试代码- Ant 或 Maven联合单元持续集成(可能是巡航控制)ClearCase 版本控制工具部署到应用服务器 最后我希望有一个自动构建和集成环境。
我什至不知道这是否可能,我非常怀疑它是否可能,但如果可以,您能告诉我怎么做吗?我只是想知道如何从打印机打印一些文本。 有什么想法吗? 最佳答案 这里有更简单的事情。 import javax.swin
我是一名优秀的程序员,十分优秀!