You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
37 lines
1.1 KiB
37 lines
1.1 KiB
1 year ago
|
import pkg_resources
|
||
|
|
||
1 year ago
|
|
||
1 year ago
|
def get_package_versions(requirements_path, output_path):
|
||
|
try:
|
||
11 months ago
|
with open(requirements_path) as file:
|
||
1 year ago
|
requirements = file.readlines()
|
||
|
except FileNotFoundError:
|
||
|
print(f"Error: The file '{requirements_path}' was not found.")
|
||
|
return
|
||
|
|
||
|
package_versions = []
|
||
|
|
||
|
for requirement in requirements:
|
||
|
# Skip empty lines and comments
|
||
9 months ago
|
if requirement.strip() == "" or requirement.strip().startswith(
|
||
|
"#"
|
||
1 year ago
|
):
|
||
1 year ago
|
continue
|
||
1 year ago
|
|
||
1 year ago
|
# Extract package name
|
||
1 year ago
|
package_name = requirement.split("==")[0].strip()
|
||
1 year ago
|
try:
|
||
9 months ago
|
version = pkg_resources.get_distribution(package_name).version
|
||
1 year ago
|
package_versions.append(f"{package_name}=={version}")
|
||
|
except pkg_resources.DistributionNotFound:
|
||
|
package_versions.append(f"{package_name}: not installed")
|
||
|
|
||
1 year ago
|
with open(output_path, "w") as file:
|
||
1 year ago
|
for package_version in package_versions:
|
||
1 year ago
|
file.write(package_version + "\n")
|
||
1 year ago
|
print(f"Versions written to {output_path}")
|
||
|
|
||
1 year ago
|
|
||
1 year ago
|
# Usage
|
||
1 year ago
|
get_package_versions("requirements.txt", "installed_versions.txt")
|