我经营一个小型在线游戏社区并处理账户数据库.
设置是这样的:
名为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]
Run Code Online (Sandbox Code Playgroud)
有一个庞大的数据库,并通过文件中的目录搜索值.
值我的意思是项目ID或IP地址,以查找和跟踪其他帐户.
但是我遇到了一个新问题,我的开发工作正在崩溃.
正如您在文件中看到的那样,行由选项卡组织.
character-equip = 0 4724 1
Run Code Online (Sandbox Code Playgroud)
如果我将值4724放在我的搜索应用程序中,我希望它打印出找到的搜索结果右侧的值1选项卡.我希望它只打印出找到的结果的值,而不是额外的结果.
所以搜索可能如下所示:
1"输入要查找的项目:"
2"输入要查找的项目:4724"
3"帐户Falcon.txt有1个!"
按任意键继续...
或者如果装备物品的数量更多
character-equip = 5 1239 102
Run Code Online (Sandbox Code Playgroud)
1."输入要查找的项目:"
2."输入要查找的项目:1239"
3."帐户Falcon2.txt有102个!"
按任意键继续...
我只想输入一个项目ID,并让它显示找到的值之后的值.白色空间是一个标签.我尝试过这样做,获得任何结果的唯一成功方法是在搜索词之间添加一个标签.因此,如果我想在cmd行中找到项目1239 id,请输入:
Enter item to find:<tab>1239<tab>
Run Code Online (Sandbox Code Playgroud)
然后它将搜索该内容并显示其中包含该项目的帐户.但是,我仍然需要单独打开帐户以查找该项目的数量.如果找到值,我希望搜索结果显示项目的数量.但是,如果该值是一个数量并且它试图搜索一个选项卡,我希望它跳过它或说零.
这就是我的意思.
character-equip = 0 1024 1239
Enter item to find: 1239
Run Code Online (Sandbox Code Playgroud)
如果它访问此帐户,我想让搜索结果显示为零,如果它无法选项卡或查看空白区域中的任何值.因此它将显示为null或零帐户Falcon3.txt为null!
要么
Account Falcon3.txt has 0!
Run Code Online (Sandbox Code Playgroud)
我试图这样做,但我不确定如何实现这一目标.
这是我的代码.
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!");
}
}
}
Run Code Online (Sandbox Code Playgroud)
谢谢你们,我希望你能帮助我.
这只是为数据库而烦恼.如果您的整个后端在单个java进程中运行,我建议使用Apache Derby或H2.
如果您不想移动到数据库,并且主要问题是将所有条目列在单个目录中的行为,您是否可以将其拆分为层次结构.然后,您的Falcon帐户可以位于F/FA/Falcon.txt中 - 每个目录将包含更易管理的文件数.