Java ArrayList从文件中读取行并分配它们
我创建了一个从文件中读取的代码,每一行都是一本不同的书,每一行都包含一个标题和一个价格。图书档案是:Java ArrayList从文件中读取行并分配它们,java,file,arraylist,Java,File,Arraylist,我创建了一个从文件中读取的代码,每一行都是一本不同的书,每一行都包含一个标题和一个价格。图书档案是: The Hobbit,$15.00 Purple Cow,$10.00 Death by Black Hole,$35.00 这些方法有效。但我正在尝试创建一种方法,其工作原理如下:输入预算:15,然后将所有BOK分配到15美元以下。我已经完成了searchForPrice方法的一部分,但它并没有真正起作用。我怎么做呢?谢谢 import java.util.*; im
The Hobbit,$15.00
Purple Cow,$10.00
Death by Black Hole,$35.00
这些方法有效。但我正在尝试创建一种方法,其工作原理如下:输入预算:15,然后将所有BOK分配到15美元以下。我已经完成了searchForPrice方法的一部分,但它并没有真正起作用。我怎么做呢?谢谢
import java.util.*;
import java.io.*;
import javax.swing.*;
public class BookStore {
private ArrayList<Book> library;
String Book;
public BookStore() throws FileNotFoundException {
library = readBooks("books1.txt");
}
public ArrayList<Book> readBooks(String path) {
ArrayList<Book> books = new ArrayList<Book>();
try{
BufferedReader br = new BufferedReader(new FileReader(path));
String line;
while ((line = br.readLine()) != null) {
String[] arr = line.split(",");
String title = arr[0];
double price = Double.parseDouble(arr[1].trim().replace("$",""));//in case has a $
books.add(new Book(title,price));
}
br.close();
}
catch (Exception e){
e.printStackTrace();
}
return books;
}
public String toString() {
String result = "";
for (Book tempBook : library) {
result += tempBook.toString() + "\n";
}
return result;
}
public ArrayList<Book> searchForTitle(String searchString) {
ArrayList<Book> searchResult = new ArrayList<Book>();
for (Book currentBook : library) {
if ((currentBook.getTitle()).indexOf(searchString) != -1)
searchResult.add(currentBook);
}
searchResult.trimToSize();
return searchResult;
}
//get lowest price book
public Book lowestPrice() {
Book lowestPrice = library.get(0);
for (Book book : library) {
if (book.getPrice() < lowestPrice.getPrice()) {
lowestPrice = book;
}
}
return lowestPrice;
}
//bookslessthanthenumbertheyenter
public ArrayList<Book> searchForPrice(double searchdouble) {
ArrayList<Book> searchPrice = new ArrayList<Book>();
for (Book currentBook : library) {
if ((currentBook.getPrice()).Double.parseDouble.indexOf(searchdouble) != -1)
searchPrice.add(currentBook);
}
searchPrice.trimToSize();
return searchPrice;
}
}
import java.util.*;
导入java.io.*;
导入javax.swing.*;
公共类书店{
私人ArrayList图书馆;
弦乐书;
public BookStore()引发FileNotFoundException{
图书馆=阅读书籍(“books1.txt”);
}
公共ArrayList readBooks(字符串路径){
ArrayList books=新建ArrayList();
试一试{
BufferedReader br=新的BufferedReader(新文件读取器(路径));
弦线;
而((line=br.readLine())!=null){
字符串[]arr=line.split(“,”);
字符串标题=arr[0];
double price=double.parseDouble(arr[1].trim().replace(“$”,”“);//如果case有$
图书。添加(新书(标题、价格));
}
br.close();
}
捕获(例外e){
e、 printStackTrace();
}
还书;
}
公共字符串toString(){
字符串结果=”;
用于(图书临时目录:图书馆){
结果+=tempBook.toString()+“\n”;
}
返回结果;
}
公共ArrayList SearchFortile(字符串搜索字符串){
ArrayList searchResult=新建ArrayList();
用于(当前图书:图书馆){
if((currentBook.getTitle()).indexOf(searchString)!=-1)
searchResult.add(currentBook);
}
searchResult.trimToSize();
返回搜索结果;
}
//买最低价的书
公共图书最低价格(){
Book lowestPrice=library.get(0);
(书籍:图书馆){
if(book.getPrice()
此循环是否编译:
for (Book currentBook : library) {
if ((currentBook.getPrice()).Double.parseDouble.indexOf(searchdouble) != -1)
searchPrice.add(currentBook);
}
在Book
类中,您将价格存储为double
,因此无需转换,只需将每本书的价格与searchdouble
进行比较即可:
for (Book currentBook : library) {
if (currentBook.getPrice() < searchdouble)
searchPrice.add(currentBook);
}
由于您没有声明任何初始容量?此循环是否编译:
for (Book currentBook : library) {
if ((currentBook.getPrice()).Double.parseDouble.indexOf(searchdouble) != -1)
searchPrice.add(currentBook);
}
在Book
类中,您将价格存储为double
,因此无需转换,只需将每本书的价格与searchdouble
进行比较即可:
for (Book currentBook : library) {
if (currentBook.getPrice() < searchdouble)
searchPrice.add(currentBook);
}
由于您没有在Java中声明任何初始容量?比较Double的最佳方法是使用Double类compare提供的函数 所以代码应该是这样的
if(Double.compare(currentBook.getPrice(),searchdouble)在Java中,比较Double的最佳方法是使用Double类提供的函数compare
所以代码应该是这样的
if(Double.compare(currentBook.getPrice(),searchdouble)您可以将其设置为if((currentBook.getPrice()).Double.parseDouble.indexOf(searchdouble)!=-1)
像这样->if(currentBook.getPrice()
但它实际上不起作用
-那么它做了什么?你做了什么调试?你验证了你的图书对象中的价格了吗?你在遍历所有图书时是否显示了你正在比较的值?不要假设你的数据或逻辑是正确的。如果((currentBook.getPrice())你可以做这个.Double.parseDouble.indexOf(searchdouble)!=-1)
像这样->if(currentBook.getPrice()
但它实际上不起作用
-那么它做了什么?你做了什么调试?你验证了你的图书对象中的价格了吗?你在遍历所有图书时是否显示了你正在比较的值?不要假设你的数据或逻辑是正确的。(1+)对于简单的双原语比较。它很简单,我就是看不出OP是如何得到这段代码的(currentBook.getPrice()).double.parseDouble.indexOf(searchdouble)!=-1
(1+)用于简单的双原语比较的。它很简单,我就是看不出OP是如何得到这段代码的(currentBook.getPrice()).Double.parseDouble.indexOf(searchdouble)!=-1