作者swpoker (swpoker)
看板java
標題[問題] 關於郵遞區號的判別
時間Wed Oct 1 13:36:28 2008
各位大大好~
我在處理從地址判斷郵遞區號 3 或 5 碼的時候
再處理前3碼部分就已經完成
就在最後的門號部份的判定
不太清楚該怎麼實作
可以有人提供想法嗎
我的想法是
public interface DoorPlateMatch {
public boolean isMatchDoorPlate(String address);
} ---> 這個用來判別輸入地址的門號是否符合
public interface PlateStrategy {
public boolean isMatchZipcodeFormat(String plate);
public DoorPlateMatch getDoorPlateMatch();
} ---> 這個用來匯入規則時~所對應的且要提供門號符合的元件
public class DoorPlateFacade {
public static DoorPlateMatch getDoorPlateMatch(String doorplateformat){
for(int i=0;i<plateStrategys.length;i++){
if(plateStrategys[i].isMatchZipcodeFormat(doorplateformat)){
return plateStrategys[i].getDoorPlateMatch();
}
}
return null;
}
static PlateStrategy [] plateStrategys = new PlateStrategy[]{
new PlateStrategy(){
/* 全 */
public DoorPlateMatch getDoorPlateMatch() {
return new DoorPlateMatch(){
public boolean isMatchDoorPlate(String address) {
return true;
}
};
}
public boolean isMatchZipcodeFormat(String plate) {
// TODO 自動產生方法 Stub
return plate.trim().equals("全");
}
}
,new PlateStrategy(){
/* 單全 */
public DoorPlateMatch getDoorPlateMatch() {
return new DoorPlateMatch(){
public boolean isMatchDoorPlate(String address) {
待實作
return true;
}
};
}
public boolean isMatchZipcodeFormat(String plate) {
// TODO 自動產生方法 Stub
return plate.trim().equals("單全");
}
}
};
} ----> 處理匯入的規則及決定是否有適當的門號判別元件
謝謝~~
以下為由郵局所提供的區碼判別規則的部份
10058,台北市,中正區,八德路1段,全
10079,台北市,中正區,三元街,單全
10070,台北市,中正區,三元街,雙 48號以下
10079,台北市,中正區,三元街,雙 50號以上
10068,台北市,中正區,大埔街,單 17號以上
.......
(可以在郵局下載此份規則)
--
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 163.29.28.137
推 jengjye:要做到後兩碼 要先把那分區規則看完吧? 感覺後兩碼分很細 10/01 14:31
→ swpoker:就是因為很細~規則很多~所以在想要怎麼弄會比較好~謝謝了 10/01 15:27
推 Lordaeron:抓郵局的excel 檔回來,再去比對會不會比你搞規則好? 10/01 23:17
推 Lordaeron:拆成樹結構,比你寫rule還要對測來得好寫. 10/02 00:44
→ swpoker:之前有試過採用decorator,可是有些情況很難處理 10/02 09:35
→ swpoker:所以我採用stratgey,來寫規則~可以順利分離規則到門號 10/02 09:37
推 Lordaeron:我的看法是與其折規則後再全測,不如拿檔回來分拆做成樹 10/02 11:03
推 Lordaeron:比較快, 參考看看吧. 10/02 11:05
→ swpoker:請問樹是指 台北縣-永和市-成功路-連單號 之類的嗎 10/02 14:49
推 Lordaeron:你怎麼拆規則就怎麼拆樹, 拆到什麼單雙號再去比大小就好 10/02 14:51
推 jengjye:其實滿煩雜的ㄟ 例如規則寫A路23號到D路99號同區 10/02 23:59
→ jengjye:但怎判斷給定地址是否包在此區塊內? 除非有完整的資料庫吧 10/03 00:02