modify scripts

This commit is contained in:
oscarz
2025-04-05 11:34:40 +08:00
parent 26ad0d7935
commit 37fef7c786
4 changed files with 115 additions and 64 deletions

View File

@ -245,7 +245,7 @@ def fetch_performers_detail_once(perfomers_list):
logging.debug(f"Fetching data for performer ({person}), url {url} ...")
soup, status_code = scraper.fetch_page(url, partial(scraper.generic_validator, tag="div", identifier="headshot", attr_type="id"))
if soup:
data = scraper.parse_page_performer(soup)
data = scraper.parse_page_performer(soup, url)
if data:
performer_id = db_tools.insert_or_update_performer({
'href': url,
@ -281,9 +281,13 @@ def fetch_performers_detail_once(perfomers_list):
def fetch_performers_detail():
limit_count = 5 if debug else 100
perfomers_list = []
last_perfomer_id = 0
# 获取新演员的列表
while True:
if force: # 从头逐个遍历
perfomers_list = db_tools.query_performer_hrefs(start_id=last_perfomer_id, order_by='id asc', limit=limit_count)
else: # 只做更新
perfomers_list = db_tools.query_performer_hrefs(is_full_data=0, limit=limit_count)
if len(perfomers_list) < 1:
logging.info(f'all new performers fetched. ')
@ -308,12 +312,15 @@ def fetch_performers_detail():
def fetch_movies_detail():
limit_count = 10 if debug else 100
movies_list = []
last_movie_id = 0
while True:
if force: # 从头逐个遍历
movies_list = db_tools.query_movie_hrefs(start_id=last_movie_id, order_by='id asc', limit=limit_count)
else: # 只做更新
movies_list = db_tools.query_movie_hrefs(is_full_data=0, limit=limit_count)
if len(movies_list) < 1:
logging.info(f'all movies fetched.')
break
last_movie_id = 0
succ_count = 0
for movie in movies_list:
url = movie['href']

View File

@ -343,7 +343,7 @@ def parse_credits_table(table, distributor_list):
# 请求网页并提取所需数据
def parse_page_performer(soup):
def parse_page_performer(soup, url):
# 提取数据
data = {}
@ -434,6 +434,15 @@ def parse_page_movie(soup, href, title):
values = info_div.find_all("p", class_="biodata")
for label, value in zip(labels, values):
key = label.text.strip()
if key == "Directors": # 解析多位导演的情况
directors = []
links = value.find_all("a")
for link in links:
director_name = link.text.strip()
director_href = host_url + link['href'] if link['href'] else ''
directors.append({"name": director_name, "href": director_href})
movie_data[key] = directors
else:
val = value.text.strip()
if key in ["Distributor", "Studio", "Director"]:
link = value.find("a")
@ -541,6 +550,7 @@ def parse_page_movie(soup, href, title):
"DirectorHref": movie_data.get("DirectorHref", ""),
"DistributorHref": movie_data.get("DistributorHref", ""),
"StudioHref": movie_data.get("StudioHref", ""),
"Directors": movie_data.get("Directors", []), # 可能存在的元素
"Performers": performers,
"SceneBreakdowns": scene_breakdowns,
"AppearsIn": appears_in,

View File

@ -344,6 +344,12 @@ def query_performer_hrefs(**filters):
if "is_full_data" in filters:
sql += " AND is_full_data = ?"
params.append(filters["is_full_data"])
if "start_id" in filters:
sql += " AND id > ?"
params.append(filters["start_id"])
if "order_by" in filters:
sql += " order by ? asc"
params.append(filters["order_by"])
if 'limit' in filters:
sql += " limit ?"
params.append(filters["limit"])
@ -572,7 +578,7 @@ def insert_or_update_movie(movie_data):
studio_id = get_id_by_href('iafd_studios', movie_data['StudioHref'])
director_id = get_id_by_href('iafd_performers', movie_data['DirectorHref'])
# 导演不存在的话,插入一条
if director_id is None:
if (director_id is None) and utils.is_valid_person_url(movie_data['DirectorHref']):
director_id = insert_performer_index( movie_data['Director'], movie_data['DirectorHref'], from_movie_list=1)
if studio_id is None:
studio_id = 0
@ -605,6 +611,22 @@ def insert_or_update_movie(movie_data):
logging.debug(f'insert one move, id: {movie_id}, title: {movie_data['title']}, href: {movie_data['href']}')
# 导演-电影写入 关系表
if director_id:
tmp_id = insert_performer_movie(director_id, movie_id, 'directoral', '')
if tmp_id:
logging.debug(f"insert one perfomer_movie. director_id: {director_id}, movie_id:{movie_id}")
for director in movie_data.get('Directors', []):
director_id = get_id_by_href('iafd_performers', director['href'])
# 如果演员不存在,先插入
if (director_id is None) and utils.is_valid_person_url(director['href']):
director_id = insert_performer_index(director['name'], director['href'], from_movie_list=1)
logging.debug(f"insert one director. perfomer_id: {director_id}, movie_id:{movie_id} ")
if director_id:
tmp_id = insert_performer_movie(director_id, movie_id, 'directoral', '')
if tmp_id:
logging.debug(f"insert one perfomer_movie. director_id: {director_id}, movie_id:{movie_id}")
# 插入 performers_movies 关系表
for performer in movie_data.get('Performers', []):
performer_id = get_id_by_href('iafd_performers', performer['href'])
@ -732,6 +754,12 @@ def query_movie_hrefs(**filters):
if "is_full_data" in filters:
sql += " AND is_full_data = ?"
params.append(filters["is_full_data"])
if "start_id" in filters:
sql += " AND id > ?"
params.append(filters["start_id"])
if "order_by" in filters:
sql += " order by ?"
params.append(filters["order_by"])
if 'limit' in filters:
sql += " limit ?"
params.append(filters["limit"])
@ -762,7 +790,7 @@ def get_performers_needed_update(limit=None):
return []
# 生成一个复杂的演员电影数量的查询视图,来判断从电影列表中聚合出来的演员-影片数量,与从演员列表中抓取到的影片数量,是否相等。
def create_view_and_indexes():
def check_and_create_stat_table(taskid = 0):
try:
# 检查索引是否存在,如果不存在则创建
indexes = [
@ -782,11 +810,14 @@ def create_view_and_indexes():
logging.info(f"Index {index_name} already exists.")
# 检查视图是否存在,如果不存在则创建
view_name = "view_perfomers_cnt"
cursor.execute("SELECT name FROM sqlite_master WHERE type='view' AND name=?", (view_name,))
if not cursor.fetchone():
create_view_sql = """
CREATE VIEW view_perfomers_cnt AS
view_name = f"iafd_tmp_performers_stat_{taskid}"
cursor.execute("SELECT name FROM sqlite_master WHERE type='table' AND name=?", (view_name,))
if cursor.fetchone():
cursor.execute("drop table ?", (view_name,))
conn.commit()
create_view_sql = f"""
CREATE table {view_name} AS
SELECT
id,
href,
@ -829,9 +860,7 @@ def create_view_and_indexes():
id, href, name, movies_cnt;
"""
cursor.execute(create_view_sql)
logging.info(f"View {view_name} created successfully.")
else:
logging.info(f"View {view_name} already exists.")
logging.info(f"table {view_name} created successfully.")
# 提交更改并关闭连接
conn.commit()
@ -913,7 +942,7 @@ def finalize_task_log(task_id):
logging.error(f"任务 {task_id} 结束失败: {e}")
if __name__ == "__main__":
create_view_and_indexes()
check_and_create_stat_table()
'''
try:

View File

@ -32,6 +32,11 @@ def to_number(value):
except (ValueError, TypeError):
return 0
def is_valid_person_url(url):
if 'person.rme' in url.lower():
return True
return False
def dist_stu_href_rewrite(href):
# 提取 ID适用于 distrib 或 studio
import re