ver 2022-01-26, update for fami-ticket
parent
fbf793f307
commit
275adf2d0a
|
@ -51,7 +51,7 @@ ssl._create_default_https_context = ssl._create_unverified_context
|
||||||
#附註1:沒有寫的很好,很多地方應該可以模組化。
|
#附註1:沒有寫的很好,很多地方應該可以模組化。
|
||||||
#附註2:
|
#附註2:
|
||||||
|
|
||||||
CONST_APP_VERSION = u"MaxBot (2022.01.13)"
|
CONST_APP_VERSION = u"MaxBot (2022.01.26)"
|
||||||
|
|
||||||
CONST_FROM_TOP_TO_BOTTOM = u"from top to bottom"
|
CONST_FROM_TOP_TO_BOTTOM = u"from top to bottom"
|
||||||
CONST_FROM_BOTTOM_TO_TOP = u"from bottom to top"
|
CONST_FROM_BOTTOM_TO_TOP = u"from bottom to top"
|
||||||
|
@ -2297,26 +2297,64 @@ def kktix_reg_new(driver, url, answer_index, kktix_register_status_last):
|
||||||
|
|
||||||
|
|
||||||
# PURPOSE: get target area list.
|
# PURPOSE: get target area list.
|
||||||
def get_fami_target_area(date_keyword, area_keyword_1, area_keyword_2):
|
# PS: this is main block, use keyword to get rows.
|
||||||
|
# PS: it seems use date_auto_select_mode instead of area_auto_select_mode
|
||||||
|
def get_fami_target_area(date_keyword, area_keyword_1, area_keyword_2, area_auto_select_mode):
|
||||||
|
show_debug_message = True # debug.
|
||||||
|
show_debug_message = False # online
|
||||||
|
|
||||||
areas = None
|
areas = None
|
||||||
|
|
||||||
area_list = None
|
area_list = None
|
||||||
try:
|
try:
|
||||||
#print("try to find area block")
|
if show_debug_message:
|
||||||
|
print("try to find area block by keywords...")
|
||||||
|
|
||||||
my_css_selector = "table.session__list > tbody > tr"
|
my_css_selector = "table.session__list > tbody > tr"
|
||||||
area_list = driver.find_elements(By.CSS_SELECTOR, my_css_selector)
|
area_list = driver.find_elements(By.CSS_SELECTOR, my_css_selector)
|
||||||
if area_list is not None:
|
if area_list is not None:
|
||||||
#print("lenth of row:", len(area_list))
|
area_list_length = len(area_list)
|
||||||
if len(area_list) > 0:
|
if show_debug_message:
|
||||||
|
print("lenth of area rows:", area_list_length)
|
||||||
|
|
||||||
|
if area_list_length > 0:
|
||||||
ret = True
|
ret = True
|
||||||
|
|
||||||
|
areas = []
|
||||||
|
|
||||||
if len(date_keyword)==0 and len(area_keyword_1)==0 and len(area_keyword_2) == 0:
|
if len(date_keyword)==0 and len(area_keyword_1)==0 and len(area_keyword_2) == 0:
|
||||||
# select all.
|
# select all.
|
||||||
areas = area_list
|
# PS: must travel to row buttons.
|
||||||
|
#areas = area_list
|
||||||
|
|
||||||
|
row_index = 0
|
||||||
|
for row in area_list:
|
||||||
|
row_index += 1
|
||||||
|
#print("row index:", row_index)
|
||||||
|
|
||||||
|
is_enabled = False
|
||||||
|
my_css_selector = "button"
|
||||||
|
td_button = row.find_element(By.TAG_NAME , my_css_selector)
|
||||||
|
if td_button is not None:
|
||||||
|
is_enabled = td_button.is_enabled()
|
||||||
|
|
||||||
|
if not is_enabled:
|
||||||
|
# must skip this row.
|
||||||
|
continue
|
||||||
|
else:
|
||||||
|
if show_debug_message:
|
||||||
|
print("row button is disabled!")
|
||||||
|
|
||||||
|
if is_enabled:
|
||||||
|
areas.append(td_button)
|
||||||
|
|
||||||
|
# PS: it seems use date_auto_select_mode instead of area_auto_select_mode
|
||||||
|
if area_auto_select_mode == CONST_FROM_TOP_TO_BOTTOM:
|
||||||
|
print("only need first item, break area list loop.")
|
||||||
|
break
|
||||||
|
|
||||||
else:
|
else:
|
||||||
# match keyword.
|
# match keyword.
|
||||||
areas = []
|
|
||||||
|
|
||||||
row_index = 0
|
row_index = 0
|
||||||
for row in area_list:
|
for row in area_list:
|
||||||
row_index += 1
|
row_index += 1
|
||||||
|
@ -2347,12 +2385,15 @@ def get_fami_target_area(date_keyword, area_keyword_1, area_keyword_2):
|
||||||
if not is_enabled:
|
if not is_enabled:
|
||||||
# must skip this row.
|
# must skip this row.
|
||||||
continue
|
continue
|
||||||
|
else:
|
||||||
|
if show_debug_message:
|
||||||
|
print("row button is disabled!")
|
||||||
|
|
||||||
row_text = ""
|
row_text = ""
|
||||||
try:
|
try:
|
||||||
row_text = row.text
|
row_text = row.text
|
||||||
except Exception as exc:
|
except Exception as exc:
|
||||||
print("get text fail")
|
print("get row text fail")
|
||||||
break
|
break
|
||||||
|
|
||||||
if len(row_text) > 0:
|
if len(row_text) > 0:
|
||||||
|
@ -2385,18 +2426,20 @@ def get_fami_target_area(date_keyword, area_keyword_1, area_keyword_2):
|
||||||
# add button instead of row.
|
# add button instead of row.
|
||||||
areas.append(td_button)
|
areas.append(td_button)
|
||||||
|
|
||||||
|
|
||||||
if area_auto_select_mode == CONST_FROM_TOP_TO_BOTTOM:
|
if area_auto_select_mode == CONST_FROM_TOP_TO_BOTTOM:
|
||||||
print("only need first item, break area list loop.")
|
print("only need first item, break area list loop.")
|
||||||
break
|
break
|
||||||
|
|
||||||
return_row_count = len(areas)
|
return_row_count = len(areas)
|
||||||
#print("return_row_count:", return_row_count)
|
if show_debug_message:
|
||||||
|
print("return_row_count:", return_row_count)
|
||||||
if return_row_count==0:
|
if return_row_count==0:
|
||||||
areas = None
|
areas = None
|
||||||
|
|
||||||
except Exception as exc:
|
except Exception as exc:
|
||||||
|
pass
|
||||||
print("find #session date list fail")
|
print("find #session date list fail")
|
||||||
|
if show_debug_message:
|
||||||
print(exc)
|
print(exc)
|
||||||
|
|
||||||
return areas
|
return areas
|
||||||
|
@ -2475,8 +2518,9 @@ def fami_home(driver, url):
|
||||||
print("select_by_visible_text 1 fail")
|
print("select_by_visible_text 1 fail")
|
||||||
pass
|
pass
|
||||||
except Exception as exc:
|
except Exception as exc:
|
||||||
|
pass
|
||||||
print("click buyWaiting button fail")
|
print("click buyWaiting button fail")
|
||||||
print(exc)
|
#print(exc)
|
||||||
|
|
||||||
#---------------------------
|
#---------------------------
|
||||||
# part 4: press "next" button.
|
# part 4: press "next" button.
|
||||||
|
@ -2501,7 +2545,7 @@ def fami_home(driver, url):
|
||||||
#---------------------------
|
#---------------------------
|
||||||
# part 2: select keywords
|
# part 2: select keywords
|
||||||
#---------------------------
|
#---------------------------
|
||||||
areas = get_fami_target_area(date_keyword, area_keyword_1, area_keyword_2)
|
areas = get_fami_target_area(date_keyword, area_keyword_1, area_keyword_2, area_auto_select_mode)
|
||||||
|
|
||||||
area_target = None
|
area_target = None
|
||||||
if areas is not None:
|
if areas is not None:
|
||||||
|
|
|
@ -17,7 +17,7 @@ import sys
|
||||||
import platform
|
import platform
|
||||||
import json
|
import json
|
||||||
|
|
||||||
CONST_APP_VERSION = u"MaxBot (2022.01.13)"
|
CONST_APP_VERSION = u"MaxBot (2022.01.26)"
|
||||||
|
|
||||||
CONST_FROM_TOP_TO_BOTTOM = u"from top to bottom"
|
CONST_FROM_TOP_TO_BOTTOM = u"from top to bottom"
|
||||||
CONST_FROM_BOTTOM_TO_TOP = u"from bottom to top"
|
CONST_FROM_BOTTOM_TO_TOP = u"from bottom to top"
|
||||||
|
|
Loading…
Reference in New Issue