正则表达式完成号码验证,
^以某开头,[] 字符集(匹配中括号里面的任意字符),\d是任意一个数字,{n}表示出现了多少次,$结尾
手机号的正则 ^1[34568]\d{9}$,以1开头,第二个数字是34568,剩下九个都是数字,数字结尾
调用String对象的match()方法,参数:正则(里面的斜杠\需要转义)
if (phone.matches("^1[34568]\\d{9}$")) {
SQLiteDatabase db = SQLiteDatabase.openDatabase(path, null,
SQLiteDatabase.OPEN_READONLY);
Cursor cursor = db
.rawQuery(
"select location from data2 where id=(select outkey from data1 where id=?)",
new String[] { phone.substring(0, 7) });
while (cursor.moveToNext()) {
String address = cursor.getString(0);
return address;
}
cursor.close();
}
文本输入直接查询
调用EditText对象的addTextChangedListener()方法,添加监听器,参数:TextWatcher对象
匿名内部类实现TextWatcher接口,重写onTextChanged方法,传递进来CharSequence对象
查询数据库,并展示出结果
//自动完成
et_phone.addTextChangedListener(new TextWatcher() { @Override
public void onTextChanged(CharSequence s, int arg1, int arg2, int arg3) {
phone = et_phone.getText().toString().trim();
String result = NumberQueryAddressUtil.queryAddress(phone);
tv_address.setText(result);
} @Override
public void beforeTextChanged(CharSequence arg0, int arg1, int arg2,
int arg3) {
// TODO Auto-generated method stub } @Override
public void afterTextChanged(Editable arg0) {
// TODO Auto-generated method stub }
});