搜索&显示结果[java]

时间:2009-12-29 09:39:56

标签: java user-input

我经营一个小型在线游戏社区并处理账户数据库。

设置如下:

名为Accounts的文件夹 在Accounts目录中,按玩家名称组织了200,000多个文本文件。手动访问此文件夹很麻烦,因为需要RAM进入和搜索文件。我觉得这很不方便。

我访问此目录以发送密码提醒,或者访问最长时间的人的高分。

以下是帐户文件的示例。该文件名为Falcon.txt

[ACCOUNT]
character-username = Falcon
character-password = falconpassword

[INFO]
character-coordx = 3252
character-coordy = 3432
character-active = yes
character-ismember = 1
character-messages = 5
character-lastconnection = [removed]
character-lastlogin = 2009-11-29
character-energy = 100
character-gametime = 193
character-gamecount = 183

[EQUIPMENT]
character-equip = 0 4724    0   
character-equip = 1 1052    0   
character-equip = 2 6585    0   
character-equip = 3 4151    0   
character-equip = 4 4720    0   
character-equip = 5 1215    0   
character-equip = 6 -1  0   
character-equip = 7 4722    0   
character-equip = 8 -1  0   
character-equip = 9 775 0   
character-equip = 10    1837    0   
character-equip = 11    -1  0   
character-equip = 12    6735    0   
character-equip = 13    -1  0   

[APPEARANCE]
character-look = 0  1
character-look = 1  1
character-look = 2  2
character-look = 3  3
character-look = 4  5
character-look = 5  2

[STATS]
character-skill = 0 1   0
character-skill = 1 1   0
character-skill = 2 1   0
character-skill = 3 1   0
character-skill = 4 1   0
character-skill = 5 1   0
character-skill = 6 1   0
character-skill = 7 1   0
character-skill = 8 1   0
character-skill = 9 1   0
character-skill = 10    1   0
character-skill = 11    1   0
character-skill = 12    1   0
character-skill = 13    1   0
character-skill = 14    1   0
character-skill = 15    1   0
character-skill = 16    1   0
character-skill = 17    1   0
character-skill = 18    1   0
character-skill = 19    1   0
character-skill = 20    1   0

[ITEMS]

[BANK]

[FRIENDS]

[IGNORES]

[END]

有一个庞大的数据库,并在文件目录中搜索值。

值我的意思是按商品ID或IP地址来查找和跟踪其他帐户。

但是我遇到了一个新问题,我的开发工作正在崩溃。

正如您在文件中看到的那样,行由标签组织。

character-equip = 0    4724    1 

如果我将值4724放在我的搜索应用程序中,我希望它打印出找到的搜索结果右侧的值1选项卡。我希望它只打印出找到的结果的值,而不是额外的结果。

所以搜索可能如下所示:

1“输入要查找的项目:”
2“输入要查找的项目:4724”
3“帐户Falcon.txt有1个!”
按任意键继续......

或者如果装备物品的数量更多

character-equip = 5    1239    102

1。 “输入要查找的项目:”
2.“输入要查找的项目:1239”
3.“帐户Falcon2.txt有102个!”
按任意键继续......

我只想输入一个商品ID,并让它显示找到的值之后的值。白色空间是一个标签。我尝试过这样做,获得任何结果的唯一成功方法是在搜索词之间添加一个标签。因此,如果我想在cmd行中找到项目1239 id,请输入:

Enter item to find:<tab>1239<tab>

然后它将搜索该内容并显示其中包含该项目的帐户。但是,我仍然需要单独打开帐户以查找该项目的数量。如果找到值,我希望搜索结果显示项目的数量。但是,如果该值是一个数量并且它试图搜索一个选项卡,我希望它跳过它或说零。

这就是我的意思。

character-equip = 0    1024    1239

Enter item to find: 1239

如果它访问此帐户,我想让搜索结果显示为零,如果它无法选项卡或查看空白区域中的任何值。所以它将显示为null或零     账号Falcon3.txt为空!

Account Falcon3.txt has 0!

我试图这样做,但我不确定如何实现这一点。

这是我的代码。

import java.io.*;
import java.util.*;

public class ItemDatabase {

    public static void main(String args[]) {

        System.out.print("Enter item to find: ");
        Scanner sc = new Scanner(System.in);
        find(sc.nextLine());
    }

    public static void find(String delim) {
        File dir = new File("accounts");
        if (dir.exists()) {
            String read;
            try {
                File files[] = dir.listFiles();
                for (int i = 0; i < files.length; i++) {
                    File loaded = files[i];
                    if (loaded.getName().endsWith(".txt")) {
                        BufferedReader in = new BufferedReader(new FileReader(loaded));
                        StringBuffer load = new StringBuffer();
                        while ((read = in.readLine()) != null) {
                            load.append(read + "\n");
                        }
                        String delimiter[] = new String(load).split(delim);

                        if(delimiter.length > 1) {
                        System.out.println("Account " + loaded.getName() + "has " + delimiter[1] + "!");
                        }
                    }
                }  
            } catch (Exception e) {
                e.printStackTrace();
            }
        } else {
            System.out.println("error: dir wasn't found!");
        }
    }
}

谢谢你们,我希望你能帮助我。

2 个答案:

答案 0 :(得分:6)

这只是为数据库而烦恼。如果您的整个后端在单个java进程中运行,我建议使用Apache DerbyH2之类的内容。

如果您不想迁移到数据库,并且主要问题是将所有条目列在单个目录中的行为,您是否可以将其拆分为层次结构。您的Falcon帐户可以位于F / FA / Falcon.txt中 - 每个目录将包含更易管理的文件数。

答案 1 :(得分:0)

除了需要数据库之外,您还可以使用命令行实用程序(如find,grep等)或文本处理语言(如perl)更直观,更轻松地实现解决方案。

也许

grep '[0-9]+\t[0-9]+\t1239' Account_Falcon3.txt

会返回

character-equip = 0    1024    1239

然后,您可以轻松地看到该项目的值为0.

我无法强调编写Java程序来执行此操作的必要性 - 您不会像标准shell实用程序的作者那样做得那么好。让我们面对现实,你问这个问题的事实表明你是一个新手! :)(根据主题,我们都是新手。)