android 编辑txt,.txt到可修改的android数据库

请勿通过巨大的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只允许对普及值使用“是”和“否”.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值