Beijing_Daxuexi/Beijng_Daxuexi.py

50 lines
1.7 KiB
Python
Raw Normal View History

2023-12-18 12:55:24 +00:00
import csv
2024-01-10 19:54:04 +08:00
import threading
import subprocess
2023-12-18 14:59:37 +08:00
2024-01-10 19:54:04 +08:00
def process_account(row, result_list):
username, password = row[0], row[1]
2023-12-18 14:59:37 +08:00
2024-01-10 19:54:04 +08:00
try:
output_bytes = subprocess.check_output(["python", "one_account.py", username, password])
output = output_bytes.decode('utf-8') # Use utf-8 encoding to decode the bytes
except subprocess.CalledProcessError as e:
output = f"Error: {e.output.decode('utf-8')}" # Use utf-8 encoding to decode the error output
2023-12-18 14:59:37 +08:00
2024-01-10 19:54:04 +08:00
result_list.append((username, output)) # 将结果存入结果列表
if __name__ == '__main__':
2023-12-18 12:55:24 +00:00
success = 0
count = 0
2024-01-10 19:54:04 +08:00
all_results = [] # 用于存储每个线程的结果列表
2023-12-18 12:55:24 +00:00
with open('account.csv', 'r', encoding='utf-8') as f:
reader = csv.reader(f)
2024-01-10 19:54:04 +08:00
threads = []
2023-12-18 12:55:24 +00:00
for row in reader:
count += 1
2024-01-10 19:54:04 +08:00
print(f'用户{count}: {row[2]}({row[0]})')
# 创建一个线程并启动,为每个线程创建独立的结果列表
results = []
thread = threading.Thread(target=process_account, args=(row, results))
threads.append(thread)
thread.start()
# 将每个线程的结果列表存入总的结果列表
all_results.append(results)
# 等待所有线程执行完毕
for thread in threads:
thread.join()
print('\n所有用户运行完毕\n')
# 统计成功和失败的用户
for results in all_results:
for username, output in results:
if "Error" not in output:
2023-12-18 12:55:24 +00:00
success += 1
2024-01-10 19:54:04 +08:00
print(f'用户{username}运行结果:\n{output}')
print(f'{count}个用户,成功{success}个,失败{count - success}')