请勿通过巨大的txt文件分发您的应用,并将其导入用户设备.这需要时间并且很烦人.
而是使用预先填充的数据库分发您的应用程序,然后从res文件夹复制它.您可以使用android-sqlite-asset-helper自动执行此操作.
还可以数据库始终存储在内部存储器中,您不能在非根目录设备上访问它(除非您正在使用AVD).
要将txt内容导入数据库,请创建脚本或用于解析内容并执行相应SQL查询的内容.同样,您的应用应随数据库一起提供,而不应随原始文件一起提供!
我有点无聊,并且一起编写了一个简短的Python脚本,以从您的txt文件中读取所有条目并将它们插入到SQLite数据库中:
import sqlite3
import re
counter = 0;
pattern = re.compile('^([^\^]+)\^([\w\s]+)\^(yes|no)\^\w+$');
conn = sqlite3.connect("imported.db");
cursor = conn.cursor();
# Create the Table:
conn.execute('''
CREATE TABLE Bands (
name TEXT,
genre TEXT,
popular INTEGER,
selected INTEGER
);''');
# Now, insert:
with open('bands.txt', 'r') as f:
for line in f:
match = pattern.search(line);
if match:
cursor.execute('''
INSERT INTO Bands (name, genre, popular, selected)
VALUES (?,?,?,0)''',
(
match.group(1), match.group(2),
(1 if match.group(3) == 'yes' else 0)
)
);
counter+=1;
conn.commit();
conn.close();
print "Imported ", counter, " bands!";
这将假定txt文件名为bands.txt,每个值都用/分隔,并且每个条目都位于其自己的行上.生成的数据库文件为import.db.
另外,我对所有True | False字段(流行的,选定的)都使用INTEGER.然后,这些将为false保留0,为true保留1.
最后但并非最不重要的一点是,RegEx只允许对普及值使用“是”和“否”.