在Java中解析文本文件时出现问题
我已经看了所有的链接,似乎无法得到我要找的。我有一个文本文件需要读入。首先是文本文件格式:
3 STL NY Chi //all on one line
STL NY 575 //on its own line
NY Chi 550 //on its own line
STL Chi 225 //on its own line
我需要将int读入一个int变量,比如我们称之为count。然后将同一条线上的实际城市排列成一个数组。接下来的几行需要读入一个数组,其中里程数与数组相关联,例如[STL NY]=575。我只能使用数组。没有哈希表、列表、堆栈或队列。这是我到目前为止得到的,老实说,这并不多。我真的需要一些帮助,因为我在这件事上“怎么做”的问题上很困惑
import java.io.*;
import java.util.*;
public class P3 {
/**
* @param args the command line arguments
*/
public static int count;
public static void main(String[] args) {
try {
FileInputStream dataFile = new FileInputStream("Data.txt");
//BufferedReader br = new BufferedReader(new InputStreamReader(dataFile));
String line = br.readLine();
}
catch (IOException e) {
System.err.println ("Unable to open file");
System.exit(-1);
}
}
}
我想我已经做到了,但是我得到了一个错误代码:“不能从静态上下文引用非静态变量城市。”我试图通过打印来测试我的代码。有人能帮我印刷吗?我想看看数组中有什么,以确保我做得正确。这是我的密码:
package p3;
import java.io.*;
import java.util.*;
class citiesDist {
String cityOne;
String cityTwo;
int miles;
}
class city {
String cityName;
int numberLinks;
citiesDist[] citiesDists;
}
public class P3 {
city[] cities;
void initCity(int len) {
for (int i = 0; i < len; i++) {
cities[i] = new city();
}
}
void initCitiesDist (int index, int len) {
for (int i = 0; i < len; i++) {
cities[index].citiesDists[i] = new citiesDist();
}
}
void parseFile() throws FileNotFoundException, IOException {
FileInputStream fstream = new FileInputStream("Data.txt");
DataInputStream in = new DataInputStream(fstream);
BufferedReader br = new BufferedReader(new InputStreamReader(in));
int numberCities = Integer.parseInt(br.readLine());
cities = new city[numberCities];
initCity(numberCities);
for (int i = 0; i < numberCities; i++) {
String line = br.readLine();
int numberLink = Integer.parseInt(line.split(" ")[1]);
cities[i].cityName = line.split(" ")[0];
cities[i].numberLinks = numberLink;
initCitiesDist (i, numberLink);
for (int j = 0; j < numberLink; j++){
line = br.readLine();
cities[i].citiesDists[j].cityOne = line.split(" ")[0];
cities[i].citiesDists[j].cityTwo = line.split(" ")[1];
cities[i].citiesDists[j].miles = Integer.parseInt(line.split(" ")[2]);
}
}
}
public static void main(String args[]) {
System.out.println("city" + cities.city);
}
}
# 1 楼答案
如果你曾经被代码难倒,不要考虑编程语言;这只会进一步混淆你的逻辑。(将算法与语言分开。)当你清楚地知道你想要完成什么时,加入你的语言(比如,“我如何完成这个特定任务?”)
最终目标
从您的设计中,您的目标是拥有一个与每个城市之间的距离相关的图表。它看起来像这样:
就文件输入和^{} 类而言,这并不太难实现
第一步
您必须提取图形的维度(3乘3)。这在输入文件的第一行中为您提供。从含有
File
的Scanner
中获取整数并不太困难,只要确保导入了正确的类,以及正确的错误处理(或者try...catch
或者抛出异常)您需要两个阵列—一个用于城市,另一个用于距离本身。我们不知道它们有多大(你从不假设文件中的数据,你只假设数据的形式),所以我们必须从文件本身获取数据。幸运的是,我们得到了一个整数,后跟城市本身。我们将读取此整数一次,并在多个不同位置使用它
这个练习是给读者听的
现在,您已经设置好数据结构并准备就绪。从这里开始,您需要做的是弥合城市阵列和距离阵列之间的差距。考虑他们到达文件的顺序,以及我们遇到的顺序。你可以用一些方法或方式来回答这个问题,“STL和NY哪个先到?”
试一试,看看你是否能走得更远