Skip to content

Latest commit

 

History

History
71 lines (58 loc) · 1.95 KB

readme.md

File metadata and controls

71 lines (58 loc) · 1.95 KB

Python script used for running Excel report from .xlsx file(s)

Starting Out:

1. Download openpyxl via pip: https://pypi.org/project/openpyxl/

2. Open Python interpretor and type pip install openpyxl

3. The sample code I've provided is just that, a sample. I highly recommend spending some time reading the documentation of Openpyxl to accodimate your specific needs at the following: https://openpyxl.readthedocs.io/en/stable/

Load the workbook

file_path = 'C:\\Users\\USER\\...\\report_1.xlsx'
wb = openpyxl.load_workbook(file_path)

Access the first sheet in the workbook

sheet = wb.active

Rename the sheet to what you want

sheet.title = 'report_1'

Manipulation(s):

#Cut Column Q and insert it in front of Column A:

col_q = [cell.value for cell in sheet['Q']]
sheet.insert_cols(1)  # Insert a new column at position 1 (A)
for idx, value in enumerate(col_q, start=1):
  sheet.cell(row=idx, column=1, value=value)
sheet.delete_cols(18)  # Delete the original column Q (now at position 18)

Wrap text for all cells except for the first row

for row in sheet.iter_rows(min_row=2):
  for cell in row:
    cell.alignment = Alignment(wrap_text=True)

Center align columns excluding the first row

for row in sheet.iter_rows(min_row=2):
  for cell in row:
    if cell.column_letter in ['D', 'E', 'F', 'I', 'M', 'N', 'J']:
      cell.alignment = Alignment(horizontal='center')

Add commas for columns G and H excluding the first row

for row in sheet.iter_rows(min_row=2):
  for cell in row:
    if cell.column_letter in ['G', 'H', 'I']:
      cell.number_format = '#,##0'

Format columns J, K, and L as currency excluding the first row

for row in sheet.iter_rows(min_row=2):
  for cell in row:
    if cell.column_letter in ['K', 'L', 'M']:
      cell.number_format = '"$"#,##0.00'

Save the modified workbook

wb.save('C:\\Users\\USER\\...\\report_1.xlsx')