-
Notifications
You must be signed in to change notification settings - Fork 0
/
rq_try_install_requirements.py
executable file
·73 lines (60 loc) · 3.5 KB
/
rq_try_install_requirements.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
#!/usr/bin/env python3
import os
import subprocess
import logging
# Cesta k root adresáři projektu
PROJECT_PATH = os.path.dirname(os.path.abspath(__file__))
# Název souboru logu je stejný jako název skriptu s příponou .log
LOG_FILE = os.path.splitext(os.path.basename(__file__))[0] + ".log"
# Nastavení loggeru
logging.basicConfig(filename=LOG_FILE, level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
logger = logging.getLogger()
logger.info(" ")
logger.info("*" * 80)
logger.info("Pokus o instalaci knihoven...")
# Pokud existuje requirements.txt, zpracuj ho
requirements_path = os.path.join(PROJECT_PATH, "requirements.txt")
err=[]
if os.path.isfile(requirements_path):
logger.info("Non-standard, non-project libraries used in the project:")
with open(requirements_path, "r") as requirements_file:
for line in requirements_file:
package = line.split('=')[0].strip()
package2 = None
if package.startswith("python_"):
package2 = package.replace("python_", "", 1)
logger.info(f"--- {line.strip()} ---")
# Pokus o instalaci balíčku pomocí apt
logger.info(f"Pokus o instalaci '{package}' pomocí apt...")
result = subprocess.run(["sudo", "apt", "install", "-y", f"python3-{package}"], capture_output=True)
if result.returncode == 0:
logger.info(f"OK: Balíček '{package}' byl úspěšně nainstalován pomocí apt.")
continue
if package2:
logger.warning(f"Nepodařilo se nainstalovat balíček {package} pomocí apt. Pokus o instalaci {package2} pomocí apt...")
logger.info(f"Pokus o instalaci bez prefixu 'python_' {package2} pomocí apt...")
result = subprocess.run(["sudo", "apt", "install", "-y", f"python3-{package2}"], capture_output=True)
if result.returncode == 0:
logger.info(f"OK: Balíček '{package2}' byl úspěšně nainstalován pomocí apt.")
continue
# Pokud instalace pomocí apt selže, pokus o instalaci pomocí pipx
logger.warning(f"Nepodařilo se nainstalovat balíček {package} pomocí apt. Pokus o instalaci pomocí pipx...")
result = subprocess.run(["pipx", "install", package], capture_output=True)
if result.returncode == 0:
logger.info(f"OK: Balíček '{package}' byl úspěšně nainstalován pomocí pipx.")
continue
# Pokud instalace selže a název balíčku má prefix "python_", zkusit znovu bez prefixu
if package2:
logger.warning(f"Nepodařilo se nainstalovat balíček {package} pomocí pipx. Pokus o instalaci {package2} pomocí pipx...")
result = subprocess.run(["pipx", "install", package2], capture_output=True)
if result.returncode == 0:
logger.info(f"OK: Balíček '{package2}' byl úspěšně nainstalován pomocí pipx.")
continue
logger.error(f"Nepodařilo se nainstalovat balíček {package} pomocí apt ani pipx.")
err.append(package)
if err:
logger.error(f"Chyba: Nepodařilo se nainstalovat následující balíčky: {', '.join(err)}")
else:
logger.info("SUCCESS: Všechny balíčky byly úspěšně nainstalovány.")
else:
logger.error("Chyba: Nepodařilo se najít requirements.txt")