- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我最近在大学进行了一次java小类测试,我需要帮助。
我有一个名为“Products”的对象,它采用(String、double、int)作为参数。
我创建了一个ArrayList
ArrayList<Product> products = new ArrayList<>();
我想做的是使用 StringTokenizer 读取这种格式并将它存储到单独的对象中,然后我想打印出对象内容。
PR0001 7.99 10
PR0002 29.99 0
PR0003 5.99 25
PR0004 99.99 50
PR0005 17.99 15
PR0006 15.99 0
PR0007 19.99 35
PR0008 39.99 40
PR0009 2.99 0
PR0010 3.99 5
我的主要方法是:
package objects;
import java.util.ArrayList;
import java.util.Scanner;
import java.io.File;
import java.io.FileNotFoundException;
import java.util.StringTokenizer;
public class main_object_class
{
public static void main(String[] args)
{
ArrayList<Product> products = new ArrayList<>();
String fileName = "products.txt";
try
{
Scanner file = new Scanner(new File(fileName));
while(file.hasNextLine())
{
StringTokenizer strToken = new StringTokenizer(file.next(), " ");
while(strToken.hasMoreTokens())
{
String pCode = strToken.nextToken();
System.out.println("pCode Works");
double pPrice = Double.parseDouble(strToken.nextToken());
System.out.println("pPrice Works");
int pQuantity = Integer.parseInt(strToken.nextToken());
System.out.println("pQuantity Works");
products.add(new Product(pCode,pPrice,pQuantity));
System.out.println("Storing Works");
}
}
for(int i=0;i<products.size();i++)
{
System.out.println(products);
}
}catch(FileNotFoundException e)
{
e.printStackTrace();
}
}
}
我的产品方法:
package objects;
public class Product
{
private String pCode = "";
private double pPrice = 0;
private int pQuantity = 0;
public Product(String c, double p, int q)
{
pCode = c;
pPrice = p;
pQuantity = q;
}
public void setCode(String c)
{
pCode = c;
}
public String getCode()
{
return pCode;
}
public void setPrice(double p)
{
pPrice = p;
}
public double getPrice()
{
return pPrice;
}
public void setQuantity(int q)
{
pQuantity = q;
}
public int getQuantity()
{
return pQuantity;
}
@Override
public String toString()
{
return "Code : " + getCode() + "\tPrice : $" + getPrice() + "\tQuantity : " + getQuantity();
}
}
我的错误:
run:
pCode Works
Exception in thread "main" java.util.NoSuchElementException
at java.util.StringTokenizer.nextToken(StringTokenizer.java:349)
at objects.main_object_class.main(main_object_class.java:24)
C:\Users\Alex\AppData\Local\NetBeans\Cache\8.1\executor-snippets\run.xml:53: Java returned: 1
BUILD FAILED (total time: 0 seconds)
我非常感谢您提供的所有意见。我已经尝试了所有解决方案并且它们都有效。但我会选择@Jerin Joseph 解决方案!
最佳答案
逐行读取文件,Scanner::nextLine()
一次读取一行。
StringTokenizer strToken = new StringTokenizer(file.nextLine(), "");
删除while(strToken.hasMoreTokens())
,您需要检查您解析的每个 token 。
将其更改为,
String pCode = "";
double pPrice = 0;
int pQuantity = 0;
if(strToken.hasMoreTokens()){
pCode = strToken.nextToken();
System.out.println("pCode Works");
}
if(strToken.hasMoreTokens()){
pPrice = Double.parseDouble(strToken.nextToken());
System.out.println("pPrice Works");
}
if(strToken.hasMoreTokens()){
pQuantity = Integer.parseInt(strToken.nextToken());
System.out.println("pQuantity Works");
}
products.add(new Product(pCode,pPrice,pQuantity));
System.out.println("Storing Works");
关于Java StringTokenizer 不同的数据类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40272224/
免责声明:我昨天才学会如何做到这一点,我很绝望 我有 3 个类(class)(Student、ClassSchedule、ClassEnrolment) public class ClassEnrol
我正在创建一个程序,它对 boolean 逻辑表达式进行标记并返回标记的字符串数组。以下是我的代码: public static String[] tokenize(String s) { S
这个问题在这里已经有了答案: StringTokenizer method equivalence (2 个回答) 关闭9年前。 我对 stringtokenizer 的 hasmoreelement
我创建了一个读取这样的文件集的方法(//...是注释,忽略它们): 5 // n jobs 2 // n tools 1 4 5 6 2 1 5 4 2 3 矩阵代表每项工作使用的工具,但在这里并不重
String a ="the STRING TOKENIZER CLASS ALLOWS an APPLICATION to BREAK a STRING into TOKENS. "; Strin
我有以下代码,它将标记字符串以创建对象列表: import java.util.StringTokenizer; public class TestStringTokenizer { priv
嗨,我正在尝试使用 java 中的 StringTokeniser 对文本文件进行标记。但问题是它只需要该行的最后一个词。需要的帮助很少。此示例代码是映射缩减函数的一部分。 String profil
我正在尝试使用 stringTokenizer 方法来读取以以下格式存储在文件中的二维数组.. 1 1 1 1 代码是... BufferedReader in = new BufferedReade
我试图从文档中仅提取小写字母数字字符: String delim = "abcdefghijklmnopqrstuvwxyz0123456789"; StringTokenizer strtok =
因此,我在分配时遇到了麻烦,我需要根据给定的参数,使用 stringtokenizer 构造和方法返回字符串的第一个或第二个标记。 EX: "3+5", 2. 其返回应为 5。现在我到目前为止所拥有的
我必须标记以下字符串 12/12/2010:{content1:[{xyz,abc}],13/12/2010:{content2:[{xyz,abc},{content3:[{aa,bb}]}] 如果
为什么 hasMoreElements 和 hasMoreTokens 返回相同的值? 最佳答案 来自 hasMoreElements() 的 javadoc /** * Returns the sa
我有这段代码来解析 url 字符串,例如“?var=val”但是当“search”只是“var=val”时,此代码失败,如何使“var=val”也能工作? StringTokenizer st
我在使用 StringTokenizer 将几行文本分解为单独的标记时遇到问题。输入的文字为 3 monkeys 但是,StringTokenizer 显然将其解释为“3monkeys”。我需要它是“
我已经编写了一个 Worker 类和 Worker 的驱动程序类..我的工作类编译正常并显示所需的输出..但是在数组和 StringTokenizer 中我面临着主要问题......并且在 TestW
我正在尝试提取文本文件中的文件名。目前,我正在使用标记器。不知何故,并非所有文件名都被正确提取。 这是我的代码: list = sc.nextLine(); token = new StringTok
Java。所以我想输入一个整数数组,然后使用 StringTokenizer 打印出最大值。我知道如何使用整数执行此操作,但是当我尝试使用数组执行此操作时,String to int 命令 (Inte
我有两个文件,名为“ride.in”和“ride.out”。 “ride.in”文件包含两行,一行包含字符串“COMBO”,另一行包含字符串“ADEFGA”。正如我所说,每个字符串都位于单独的行上,因
我试图使用 StringTokenizer 将逗号设置为文件中各行的分隔符,每行由邮政编码和城市组成(例如 01221,华盛顿特区),但我不希望第二个逗号是分隔符,因为它是城市名称的一部分。我有 2
我最近在大学进行了一次java小类测试,我需要帮助。 我有一个名为“Products”的对象,它采用(String、double、int)作为参数。 我创建了一个ArrayList ArrayList
我是一名优秀的程序员,十分优秀!