mirror of
https://github.com/Telecominfraproject/wlan-lanforge-scripts.git
synced 2025-11-01 11:18:03 +00:00
cc_9800_3504.py:COPYWRITE cc_module_9800_3504.py:COPYWRITE cc_module_test.py:COPYWRITE controller.py:COPYWRITE lf_tx_power.py:COPYWRITE py-scripts/lf_csv.py:COPYWRITE py-scripts/lf_graph.py:COPYWRITE py-scripts/lf_kpi_csv.py:COPYWRITE py-scripts/lf_pcap.py:COPYWRITE py-scripts/lf_report_test.py:COPYWRITE py-scripts/lf_snp_test.py:COPYWRITE Signed-off-by: Chuck SmileyRekiere <chuck.smileyrekiere@candelatech.com>
82 lines
2.4 KiB
Python
Executable File
82 lines
2.4 KiB
Python
Executable File
#!/usr/bin/env python3
|
|
'''
|
|
NAME: lf_csv.py
|
|
|
|
PURPOSE:
|
|
Common Library for generating csv for LANforge output
|
|
KPI - Key Performance Indicators
|
|
|
|
SETUP:
|
|
/lanforge/html-reports directory needs to be present or output generated in local file
|
|
|
|
EXAMPLE:
|
|
see: /py-scripts/lf_report_test.py for example
|
|
|
|
COPYRIGHT:
|
|
Copyright 2021 Candela Technologies Inc
|
|
License: Free to distribute and modify. LANforge systems must be licensed.
|
|
|
|
INCLUDE_IN_README
|
|
'''
|
|
|
|
import pandas as pd
|
|
from pandas import *
|
|
from csv import reader
|
|
import csv
|
|
|
|
class lf_csv:
|
|
def __init__(self,
|
|
_columns=['Stations', 'bk', 'be', 'vi', 'vo'],
|
|
_rows=[['sta0001', 'sta0002', 'sta0003', 'sta0004', 'sta0005'],
|
|
[1, 2, 3, 4, 5],
|
|
[11, 22, 33, 44, 55],
|
|
[6, 7, 8, 9, 10],
|
|
[66, 77, 88, 99, 100]],
|
|
_filename='test.csv'):
|
|
self.rows = _rows
|
|
self.columns = _columns
|
|
self.filename = _filename
|
|
|
|
def generate_csv(self):
|
|
df = {}
|
|
if self.rows != []:
|
|
for i in range(len(self.columns)):
|
|
df[self.columns[i]] = self.rows[i]
|
|
else:
|
|
for i in range(len(self.columns)):
|
|
df[self.columns[i]] = []
|
|
csv_df = pd.DataFrame(df)
|
|
print(csv_df)
|
|
csv_df.to_csv(self.filename, index=False, encoding='utf-8', na_rep='NA', float_format='%.2f')
|
|
|
|
def read_csv(self, file_name, column=None):
|
|
data = read_csv(str(file_name))
|
|
value = data[str(column)].tolist()
|
|
print("value of column", value)
|
|
return value
|
|
|
|
def read_csv_row(self, file_name):
|
|
lst = []
|
|
with open(str(file_name), 'r') as read_obj:
|
|
# pass the file object to reader() to get the reader object
|
|
csv_reader = reader(read_obj)
|
|
# Iterate over each row in the csv using reader object
|
|
for row in csv_reader:
|
|
# row variable is a list that represents a row in csv
|
|
print(row)
|
|
lst .append(row)
|
|
print("list", lst)
|
|
return lst
|
|
|
|
def open_csv_append(self, fields, name):
|
|
# fields = ['first', 'second', 'third']
|
|
with open(str(name), 'a') as f:
|
|
writer = csv.writer(f)
|
|
writer.writerow(fields)
|
|
def main():
|
|
test = lf_csv()
|
|
test.generate_csv()
|
|
|
|
if __name__ == "__main__":
|
|
main()
|