我经营一个小型在线游戏社区并处理账户数据库。
设置如下:
名为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!");
}
}
}
谢谢你们,我希望你能帮助我。
答案 0 :(得分:6)
这只是为数据库而烦恼。如果您的整个后端在单个java进程中运行,我建议使用Apache Derby或H2之类的内容。
如果您不想迁移到数据库,并且主要问题是将所有条目列在单个目录中的行为,您是否可以将其拆分为层次结构。您的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实用程序的作者那样做得那么好。让我们面对现实,你问这个问题的事实表明你是一个新手! :)(根据主题,我们都是新手。)