From 8cc574b24a96fa548454e88be60777f03d0a76db Mon Sep 17 00:00:00 2001 From: "Emanuel Don (GB)" Date: Mon, 30 Dec 2024 16:12:46 +0000 Subject: [PATCH] WIP - script works but needs tidy up and tweaking (not all APs are shown) --- .gitignore | 4 ++- script.py | 75 +++++++++++++++++++++++++++++++++++++++++++++++++++++- 2 files changed, 77 insertions(+), 2 deletions(-) diff --git a/.gitignore b/.gitignore index f5e96db..2298396 100644 --- a/.gitignore +++ b/.gitignore @@ -1 +1,3 @@ -venv \ No newline at end of file +venv +.env +*.xlsx \ No newline at end of file diff --git a/script.py b/script.py index 40e4e68..8c5efe2 100644 --- a/script.py +++ b/script.py @@ -1,3 +1,76 @@ import os +import re +from dotenv import load_dotenv +from netmiko.cisco.cisco_wlc_ssh import CiscoWlcSSH +import pandas as pd -print("Hello world!") \ No newline at end of file +load_dotenv() + +ip = input("Please input the WLC IP: ") +user = os.environ.get("USER") +password = os.environ.get("PASS") + +wlc = CiscoWlcSSH( + ip=ip, + username=user, + password=password +) + +wlc.send_command("config paging disable") +ap_summary = wlc.send_command("show ap summary", read_timeout=30) + +pattern = re.compile(r""" + (?P\S+)\s+ # AP Name (non-space characters followed by spaces) + (?P\d+)\s+ # Slots (digits followed by spaces) + (?P[\w\-]+)\s+ # AP Model (alphanumeric or hyphen) + (?P[0-9a-fA-F:]+)\s+ # Ethernet MAC address (hexadecimal, colon-separated) + (?P[\w\s\-]+)\s+ # Location (alphanumeric, space, or hyphen) + (?P\w+)\s+ # Country (two uppercase letters) + (?P\d+\.\d+\.\d+\.\d+)\s+ # IP Address (IPv4 format) + (?P\d+)\s+ # Clients (digits) + (?P\[.*\]) # DSE Location (list format) +""", re.VERBOSE) + +# List to store parsed dictionaries +parsed_data = [] + +# Process each row in the text (excluding the header and separator) +for line in ap_summary.strip().splitlines()[2:]: + match = pattern.match(line) + if match: + parsed_data.append(match.groupdict()) + +# Create a DataFrame from the parsed data +df = pd.DataFrame(parsed_data) + +# Define the Excel file name +file_name = 'ap_data.xlsx' + +with pd.ExcelWriter(file_name, engine='openpyxl') as writer: + # Write the dataframe to the first sheet without the header row + df.to_excel(writer, index=False, header=False, sheet_name='AP Data') + + # Access the workbook and the sheet + workbook = writer.book + worksheet = workbook['AP Data'] + from openpyxl.utils import get_column_letter + # Set the column headers to letters (A, B, C, D, etc.) + for idx in range(len(df.columns)): + # Convert the column index (starting from 0) to Excel letters (A, B, C, ...) + worksheet[get_column_letter(idx + 1) + '1'].value = get_column_letter(idx + 1) + + # Set the column width for better readability + column_widths = {} + for col in df.columns: + max_length = max(df[col].astype(str).map(len).max(), len(col)) + 2 # Add a bit of padding + column_widths[col] = max_length + + for idx, width in enumerate(column_widths.values()): + worksheet.column_dimensions[get_column_letter(idx + 1)].width = width + + # Add a bold header row (A, B, C, D, etc.) + for cell in worksheet[1]: + cell.font = cell.font.copy(bold=True) + +# Let the user know the file has been saved +print(f"Excel file '{file_name}' has been created successfully.") \ No newline at end of file