實(shí)戰(zhàn)筆記_手機(jī)衛(wèi)士:號(hào)碼歸屬地查詢_數(shù)據(jù)庫(kù)操作_正則表達(dá)式

  • 數(shù)據(jù)庫(kù)操作

  • 正則表達(dá)式

  • IO流

數(shù)據(jù)庫(kù)拷貝


  • 為什么要拷貝數(shù)據(jù)庫(kù)觅玻?

我們將數(shù)據(jù)庫(kù)儲(chǔ)存在assets文件夾中刚陡,而數(shù)據(jù)庫(kù)的操作必須要將數(shù)據(jù)庫(kù)放在PATH="data/data/com.phonesafe/files/adress.db"路徑下,所以在初始化界面就需要操作數(shù)據(jù)庫(kù)的拷貝

  • 獲取PATH的路徑(getFilesDir()),
  • 判斷是否已經(jīng)存在該文件
  • 使用IO復(fù)制文件
    <pre>
    public void CopyDB(String dbname){
    File file=new File(getFilesDir(),dbname);
    if (file.exists()){
    return ;
    }
    try {
    InputStream inputStream=getAssets().open(dbname);
    FileOutputStream fileOutputStream=new FileOutputStream(file);
    int len=0;
    byte[] buffer=new byte[1024];
    while ((len=inputStream.read(buffer))!=-1){
    fileOutputStream.write(buffer,0,len);
    }
    } catch (IOException e) {
    e.printStackTrace();
    }
    }
    </pre>

數(shù)據(jù)庫(kù)操作


  • 獲取被操作的數(shù)據(jù)庫(kù)對(duì)象

  • 得到查詢數(shù)據(jù)結(jié)果的對(duì)象Curcor

  • 通過(guò)Curcor對(duì)象拿到查詢結(jié)果
    <pre>
    public class AddressDao {
    public static final String PATH="data/data/com.phonesafe/files/address.db";
    private static String address="未知號(hào)碼";
    public static String getAdress(String number){
    //獲取數(shù)據(jù)庫(kù)對(duì)象
    SQLiteDatabase database=SQLiteDatabase.openDatabase(PATH, null, SQLiteDatabase.OPEN_READONLY);
    //手機(jī)號(hào)碼特點(diǎn) 1+(3,4,5,6,7,8)+(9位數(shù)字)
    if (number.matches("^1[3-8]\d{9}$")){
    Cursor cursor = database.rawQuery("select location from data2 where id=(select outkey from data1 where id=?)",
    new String[]{number.substring(0, 7)});
    if (cursor.moveToNext()){
    address=cursor.getString(cursor.getColumnIndex("location"));
    }
    }else if (number.matches("^\d+$")){ //匹配數(shù)字
    switch (number.length()){
    case 3:
    address="報(bào)警電話";
    break;
    case 4:
    address="模擬器";
    break;
    case 5:
    address="客服電話";
    break;
    case 7:case 8:
    address="本地號(hào)碼";
    break;

              default:
                  //01088888888,可能是長(zhǎng)途電話
                  if (number.startsWith("0")&&number.length()>10){
                      Cursor cursor = database.rawQuery("select location from data2 where area=?",
                              new String[]{number.substring(1, 4)});
                      if (cursor.moveToNext()){
                          address=cursor.getString(cursor.getColumnIndex("location"));
                      }else {
                          cursor.close();
                          cursor=database.rawQuery("select location from data2 where area=?",
                                  new String[]{number.substring(1, 3)});
                          if (cursor.moveToNext()) {
                              address = cursor.getString(cursor.getColumnIndex("location"));
                          }
                          cursor.close();
    
                      }
                 }
                  break;
          }
      }
    
      database.close();
      return address;
    

    }
    }
    }
    </pre>

  1. 首先獲取打開(kāi)數(shù)據(jù)庫(kù)的對(duì)象为牍,這里有三個(gè)參數(shù)馅精,第一個(gè)參數(shù)代表數(shù)據(jù)庫(kù)的地址次慢,第三個(gè)表示數(shù)據(jù)庫(kù)的訪問(wèn)權(quán)限
  2. 調(diào)用了rawQuery方法旁涤,這個(gè)方法的第一個(gè)參數(shù)是數(shù)據(jù)庫(kù)的Sql語(yǔ)句翔曲,第二參數(shù)代表的是Sql語(yǔ)句占位符的參數(shù),
    number.subString(0劈愚,7)表示截取0-7位的數(shù)據(jù)瞳遍,因?yàn)樾枰娫挼那?位查詢。

正則表達(dá)式對(duì)號(hào)碼的判斷


  • 標(biāo)準(zhǔn)手機(jī)號(hào)碼判斷
  • 標(biāo)準(zhǔn)電話號(hào)碼判斷
  • 區(qū)號(hào)判斷
  1. 手機(jī)號(hào)碼特點(diǎn) 1+(3,4,5,6,7,8)+(9位數(shù)字)判斷是否為手機(jī)號(hào)碼菌羽,Then判斷歸屬地掠械。
  2. 根據(jù)電話號(hào)碼的長(zhǎng)度判斷電話號(hào)碼類型
  3. 根據(jù)區(qū)號(hào)(前提為電話號(hào)碼,長(zhǎng)度大于8算凿,截取前3或4位)判斷歸屬地
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末份蝴,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子氓轰,更是在濱河造成了極大的恐慌,老刑警劉巖浸卦,帶你破解...
    沈念sama閱讀 218,122評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件署鸡,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡限嫌,警方通過(guò)查閱死者的電腦和手機(jī)靴庆,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)怒医,“玉大人炉抒,你說(shuō)我怎么就攤上這事≈商荆” “怎么了焰薄?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,491評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)扒袖。 經(jīng)常有香客問(wèn)我塞茅,道長(zhǎng),這世上最難降的妖魔是什么季率? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,636評(píng)論 1 293
  • 正文 為了忘掉前任野瘦,我火速辦了婚禮,結(jié)果婚禮上飒泻,老公的妹妹穿的比我還像新娘鞭光。我一直安慰自己,他們只是感情好泞遗,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,676評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布惰许。 她就那樣靜靜地躺著,像睡著了一般刹孔。 火紅的嫁衣襯著肌膚如雪啡省。 梳的紋絲不亂的頭發(fā)上娜睛,一...
    開(kāi)封第一講書(shū)人閱讀 51,541評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音卦睹,去河邊找鬼畦戒。 笑死,一個(gè)胖子當(dāng)著我的面吹牛结序,可吹牛的內(nèi)容都是我干的障斋。 我是一名探鬼主播,決...
    沈念sama閱讀 40,292評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼徐鹤,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼垃环!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起返敬,我...
    開(kāi)封第一講書(shū)人閱讀 39,211評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤遂庄,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后劲赠,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體涛目,經(jīng)...
    沈念sama閱讀 45,655評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,846評(píng)論 3 336
  • 正文 我和宋清朗相戀三年凛澎,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了霹肝。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,965評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡塑煎,死狀恐怖沫换,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情最铁,我是刑警寧澤讯赏,帶...
    沈念sama閱讀 35,684評(píng)論 5 347
  • 正文 年R本政府宣布,位于F島的核電站炭晒,受9級(jí)特大地震影響待逞,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜网严,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,295評(píng)論 3 329
  • 文/蒙蒙 一识樱、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧震束,春花似錦怜庸、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,894評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至嘉栓,卻和暖如春宏榕,著一層夾襖步出監(jiān)牢的瞬間拓诸,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,012評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工麻昼, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留奠支,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,126評(píng)論 3 370
  • 正文 我出身青樓抚芦,卻偏偏與公主長(zhǎng)得像倍谜,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子叉抡,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,914評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 很實(shí)用的編程英語(yǔ)詞庫(kù)尔崔,共收錄一千五百余條詞匯。 第一部分: application 應(yīng)用程式 應(yīng)用褥民、應(yīng)用程序app...
    春天的蜜蜂閱讀 1,362評(píng)論 0 22
  • Java基礎(chǔ)常見(jiàn)英語(yǔ)詞匯(共70個(gè))['?bd?ekt] ['?:rientid]導(dǎo)向的 ...
    今夜子辰閱讀 3,287評(píng)論 1 34
  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理季春,服務(wù)發(fā)現(xiàn),斷路器轴捎,智...
    卡卡羅2017閱讀 134,657評(píng)論 18 139
  • 習(xí)慣 看春天的嫩柳 聞夏季的繁花 觀秋季的落葉 賞冬季的雪 卻更加習(xí)慣 一個(gè)人 車(chē)水馬龍的街道 習(xí)慣 一個(gè)人走 悠...
    夏季的雪閱讀 218評(píng)論 3 1
  • 我注六經(jīng)是一種讀書(shū)方式鹤盒,讀書(shū)就是要用的,能注六經(jīng)侦副,說(shuō)明自己已經(jīng)會(huì)用到書(shū)中的觀點(diǎn)來(lái)完善自己,或者提供一種解決問(wèn)題的方...
    陌塵_8bf7閱讀 331評(píng)論 0 0