Добро пожаловать! Игровой форум WLUX.NET - Игры, Читы, Скрипты, Статьи, Софт, Курсы.

Присоединяйтесь к нам сейчас, чтобы получить доступ ко всем нашим функциям. После регистрации и входа в систему вы сможете создавать темы, публиковать ответы на существующие темы, повышать репутацию участников, скачивать вложения и файлы и многое, многое другое. Так чего же вы ждете?

Добро пожаловать гость!

Приветствуем вас на нашем форуме! Мы очень рады вас видеть и с большим удовольствием поделимся всей информацией нашего форума!

Мы уважаем своих пользователей и так же ждем от вас приятного общения.

Система наград, ежедневное пополнения тем!

Общайся, получай награды.

Статьи, гайды, софт

У нас вы можете скачать бесплатно читы для игр. Полезные гайды на любые темы и схемы заработка. Есть раздел халявы!

FAQ по форуму

Не понимаю, как и что тут работает у вас?!Как создавать темы, писать сообщения, как получать реакции. Почему не засчитывает сообщения. Все ответы здесь

  • Добро пожаловать на сайт - wlux.net!

    FAQ по форуму

    1. Все сообщения до группы местный проходят модерацию от 1 минуты до 24 часа

    2. Сообщения учитываються в следующих разделах: Читать

    3.Что-бы скачать вложение нужно 2 сообщения.

    4.Личные переписки работают только с Администрацией форума

    5. Запрещено: Просить скрытый текст , спам, реклама, скам, ддос, кардинг и другая чернуха, нарушать любые законы РФ/СНГ = бан аккаунта

    6. Внимание! Мы не удаляем аккаунты с форума! Будьте внимательны ДО регистрации! Как удалить аккаунт на форуме?!

    5.Не понимаю, как и что тут работает у вас?!Как создавать темы, писать сообщения, как получать реакции. Почему не засчитывает сообщения. Все ответы здесь

Гайд Создаем многопоточный чекер для «Fragment»

wlux.net Оффлайн

wlux.net

Где волчьи уши, там волчьи зубы.
Команда форума
LV
7
 
20.06.2022
23 845
218
36
Награды
10
Пол
Муж.

Репутация:

  • Автор темы
  • Администратор
  • Модератор
  • Команда форума
  • #1

Суть​

Для начала устанавливаем библиотеки для парсинга и самого чека (также beauty улучшение):

Код:
pip install bs4 requests tqdm

Отлично, теперь нам надо узнать, как чекать. Я сделал так. Открыл Fragment.

1c4eed10c45f94b622511.png

Ввел свой юзернейм и меня перебросило на

Пожалуйста, войдите или зерегистрируйтесь, чтобы увидеть скрытый текст.

.

87e704339fb0b5927c4f1.png

а если перейти по кнопке юзернейма, то откроется

Пожалуйста, войдите или зерегистрируйтесь, чтобы увидеть скрытый текст.

.

ad597d8211b1cbebbfd5d.png

Я подумал, что если поставить желаемый юзер в

Пожалуйста, войдите или зерегистрируйтесь, чтобы увидеть скрытый текст.

, то нас перенесет на страницу покупки.

Возьмем юзернейм, который никто бы не выбрал. Например @csdjkhhbchsbdjch. Таким образом, наша ссылка будет выглядеть так:

Пожалуйста, войдите или зерегистрируйтесь, чтобы увидеть скрытый текст.

. Она перенесет нас на

Пожалуйста, войдите или зерегистрируйтесь, чтобы увидеть скрытый текст.

.

О чем это говорит? Только что, мы с вами поняли, что если юзернейм свободный, то нас переносит на

Пожалуйста, войдите или зерегистрируйтесь, чтобы увидеть скрытый текст.

.

Приступаем к написанию кода.

Импортируем нужные библиотеки:

Код:
pip install bs4 requests tqdm
from bs4 import BeautifulSoup # сам парс
import requests # запросы
from tqdm import tqdm # для бара
from concurrent.futures import ThreadPoolExecutor, Executor # многопоточность
import time # для времени

Теперь напишем сам класс чекера:

Код:
class UserName():



  def __init__(self, lines: list, threads: int) -> None:



    self.lines = lines # строчки



    self.threads = threads # колво потоков



    self.result = [] # результаты







  def run(self): # запуск



    total_lines = len(self.lines) # колво строк



    with ThreadPoolExecutor(max_workers=self.threads) as executor: # модуль для потоков



      list(tqdm(executor.map(self.parse, self.lines), total=total_lines, ascii=True, desc=" Check ")) # сам чек с визуализацией







  def parse(self, name): # сам парсинг



    name = name.strip() # удаляем лишние пробелы



    self.r = requests.get(f"https://fragment.com/username/{name}") # кидаем запрос на url



    if self.r.url == f"https://fragment.com/?query={name}": # про то что я вам говорил



      self.result.append(f" Username @{name} | Free\n")



      return # просто пустой возврат чтобы код не продолжал работу



    else: # если у нас не идет переброс на другой юрл



      try:



        bs = BeautifulSoup(self.r.text, "lxml") # парсим сайт



        res = bs.find("span", "tm-section-header-status").text # ищем текст внутри маленького окошка



        if res.lower() in ["sold", "available", "taken"]: # проверяем текст



          self.result.append(f" Username @{name} | {res}\n") # добавляем результат



          return



      except:



        self.result.append(f" Username @{name} | Unknown error\n") # просто обработка ошибок



Все расписано в комментах к коду ☝️

А теперь переходим к самому интерфейсу и запуску:

Код:
def main():



  start_time = time.time() # для подсчета времени



  _lines = input(" Загрузи файл со строками: ")



  _lines2 = input(" Загрузи файл со строками для результата: ")



  threads = input(" Введи кол-во потоков: ")



  lines = open(_lines, "r").readlines()



  checker = UserName(lines, int(threads))



  checker.run() # запуск чекера



  open(_lines2, "w").writelines(checker.result) # запись результата в файл



  print(f" Lead time: {time.time() - start_time}")







main()
 

Поиск по форуму

shape1
shape2
shape3
shape4
shape7
shape8
Верх