先来分析下 如果是搜索联系人 大概有多少种条件:
1、按姓名
2、按号码
3、按拼音简拼
4、按拼音全拼
5、按拨号盘[也就是上面的都有可能]
如果还有别的搜索策略 也可以很快的扩展的吧。
姓名、号码、全拼和简拼都在联系人表中都是可以分析出来的。
分别是display_name、number、sort_key或者sort_key_alt。
那么 就可以使用sql语句来查询了。
这里只有全拼和简拼是需要转换下,代码如下:
sort_key字段是形如:“ZHU 朱 QIANG 强”,对其解析得到需要的全拼和简拼字符串即可。
public class AnalyticString { /** * 字符串解析为字符串数组 * @param str * @return */ public String[] getStrings(String str) { return str.split(" "); } /*** * 是否为字母 * @param str * @return */ public boolean getLetter(String str) { return str.matches("^[A-Za-z]+$"); } /** * 得到全拼或简拼 * @param strs 字符串数组 * @param type 全拼还是简拼 * @return */ public String getString(String[] strs,int type) { String[] newStrs = new String[strs.length]; int j = 0; for(int i=0;i<strs.length;i++) { String firstLetter = strs[i].substring(0,1); if(getLetter(firstLetter)) { //type=0 out jp if(type==0) { newStrs[j] = firstLetter; } //type=1 out qp else { newStrs[j] = strs[i]; } j++; } } StringBuffer sb = new StringBuffer(); for(int k = 0; k < newStrs.length; k++){ if(newStrs[k] != null) { sb.append(newStrs[k]); } } return sb.toString(); } public static void main(String [] args) { AnalyticString as = new AnalyticString(); System.out.println(as.getString(as.getStrings("ZHU 朱 QIANG 强"),1)); }}
上面的代码的结果就是:ZHUQIANG
这里先分离出全拼和简拼,具体的做法如下:
ContentResolver contentResolver;String projection[] = {Phone.CONTACT_ID,Phone.DISPLAY_NAME,Phone.NUMBER,"sort_key"};Cursor cursor = contentResolver.query(Phone.CONTENT_URI, projection, getCondition(str), null, "sort_key COLLATE LOCALIZED asc");//下面是把cursor中的数据一一的读入一个List中去,其中包括全拼和简拼字段,条件变更就基于第一遍的集合过滤。public static String getCondition(String value) { String string = null; if ("".equals(value) && null==value) { return string; } else { string = "display_name like '%"+ value +"%' or data1 like '%"+ value +"%' or sort_key like '%"+ value +"%'"; return string; } }