Skip to content

DocentSzachista/web-scrap-chess-tournaments

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

GitHub issues GitHub forks GitHub stars GitHub license PyPI - Python Version Update tournaments

This is a repository that contains scripts allowing to webscrap two chess tournaments webpages:

Table of contents

Webscrapping

URL parameters

Each website have different named parameters but they actually allow for filter data in the same way.

Example URL's:

Division of url parameters

  • country / filters by country (it has only parameter on chess manager because on chess arbiter tournaments exists only for Poland)
  • country_state / wojewodztwo - filter by country_state
  • city / miejsce - filter by city
  • planned / status - filter status of tournament, in case of chessmanager it displays as /planned, /now and /finished
  • tempo / typ - filter tournament speed

Webscrapped data structure

Description of parameters:

  • link: provides link to a subpage where we can sign for a tournament
  • date: dependant on website, on chessarbiter it will display only date when its starts, when on chess manager it shows start and end dates.
  • name: tournament title
  • city: City where tournaments is being held.
  • country: Country in which tournament takes place
  • type_and_players : displays tournament tempo.

JSON example for single tournament

{
         "link": "http://www.chessarbiter.com/turnieje/open.php?turn=2022/ti_2914&n=",
         "date": "01-06",
         "name": "Grand Prix Grzybowic z okazji 100 - lecia Miasta Zabrze Turniej 8 cykl II 2022r zgłoszony do Fide",
         "city": "Zabrze",
         "country": "Poland",
         "type_and_players": "SL blitz"
},

Why only that data is being scrapped?

As intention of this script was just to automate my search for tournaments in my area, which I needed mostly info about:

  • When tournament takes place?
  • Which city?
  • What is tempo of that tournament?
  • Link to be able for signup

How to install it?

  1. Have installed at least python 3.10
  2. Have installed mongo.db database
  3. Create new virtual environment and install packages:
  • Windows
  python -m venv your_env_name
  ./your_env_name/Scripts/activate
  pip install -r /path/to/requirements.txt
  • Linux
  python3 -m venv your_env_name
  source ./your_env_name/bin/activate
  pip3 install -r /path/to/requirements.txt

How to use it?

Mailing

Add smtpServer.json with configurations for smpt server to project directory. Example file contents:

{
  "sender_email" : "example@gmail.com",
  "password": "example",
  "smtp_server": "smtp.gmail.com",
  "port" : 123
}

If you want to send emails you need to first create json file with following structure:

[
  {
    "user": "example@example.com",
    "preferences": {
      "tournament_name":"",
      "tempo_option":"",
      "tournament_status":"PLANNED",
      "country_state": "DS",
      "tournament_city":""
    }
  }
]

Next, you only need to call script:

python3 script.py mailing your-preferences-json-file 

Github actions powered script

How it works

Script webscrapps informations from websites and later saves them into tournaments.json file in docs/htmlLists directory. When its done it calls git commands to push changes into repository. Then the github pages are being rebuilt and when the process is done you can simply see data on github pages. If you want to make it actually work for your preferences I recommend to fork repository

Required files to add

In order to make script work as intended, you need to add userPreferences.json file to your project directory. It should contain following fields:

  • "tournament_name" - signs which tournament name should contain
  • "tournament_tempo" - speed in which tournament occurs
  • "tournament_status" - tournament actual state. It can be: PLANNED, FINISHED, ONGOING, ALL
  • "country_state" - country state that tournaments interest us
  • "tournament_city" - city from which we would like to get info about tournaments

Example file content:

[
    {
        "tournament_name":"",
        "tournament_tempo":"",
        "tournament_status":"PLANNED",
        "country_state": "DS",
        "tournament_city":"Wroclaw"
    },
    {
        "tournament_name":"",
        "tournament_tempo":"",
        "tournament_status":"PLANNED",
        "country_state": "LB",
        "tournament_city":""
    },
    {
        "tournament_name":"",
        "tournament_tempo":"",
        "tournament_status":"PLANNED",
        "country_state": "OP",
        "tournament_city":""
    },
    {
        "tournament_name":"",
        "tournament_tempo":"",
        "tournament_status":"PLANNED",
        "country_state": "WP",
        "tournament_city":""
    }
]

How the file is called in github actions:

  python3 ./api/script.py repository ./api/userPreferences.json

requirements.txt content

urlib 
beatifulsoup
requests
fastapi
prettytable
mongoengine
pymongo
apscheduler
"uvicorn[standard]"

Additional informations

If you want to use Google Gmail as a SMTP provider, you need to enable 2-factor authetincation because at 30.05.2022 Google has turned off simpler way to enable for use your own gmail account as SMTP service due to safe risks which that way imposed. If you want to know how to do it, here is described process the proccess.

Notes at 30.03.2023

Chessmanager has changed its form variables so it needs to be refactored