Python: Read a CSV files with initial spaces after a delimiter and remove those initial spaces
5. CSV Remove Initial Spaces
Write a Python program to read a given CSV files with initial spaces after a delimiter and remove those initial spaces.
Sample Solution:
Python Code :
import csv
print("\nWith initial spaces after a delimiter:\n")
with open('departments.csv', 'r') as csvfile:
   data = csv.reader(csvfile, skipinitialspace=False)
   for row in data:
     print(', '.join(row))
print("\n\nWithout initial spaces after a delimiter:\n")
with open('departments.csv', 'r') as csvfile:
   data = csv.reader(csvfile, skipinitialspace=True)
   for row in data:
     print(', '.join(row))
departments.csv
department_id,department_name,manager_id,location_id
10,Administration,200,1700
20,Marketing,201,1800
30,Purchasing,114,1700
40,Human Resources,203,2400
50,Shipping,121,1500
60,IT,103,1400
70,Public Relations,204,2700
80,Sales,145,2500
90,Executive,100,1700
100,Finance,108,1700
110,Accounting,205,1700
120,Treasury,,1700
130,Corporate Tax,,1700
140,Control And Credit,,1700
150,Shareholder Services,,1700
160,Benefits,,1700
170,Manufacturing,,1700
180,Construction,,1700
190,Contracting,,1700
200,Operations,,1700
210,IT Support,,1700
220,NOC,,1700
230,IT Helpdesk,,1700
240,Government Sales,,1700
250,Retail Sales,,1700
260,Recruiting,,1700
270,Payroll,,1700
Sample Output:
With initial spaces after a delimiter: department_id, department_name, manager_id, location_id 10, Administration, 200, 1700 20, Marketing, 201, 1800 30, Purchasing, 114, 1700 40, Human Resources, 203, 2400 50, Shipping, 121, 1500 60, IT, 103, 1400 70, Public Relations, 204, 2700 80, Sales, 145, 2500 90, Executive, 100, 1700 100, Finance, 108, 1700 110, Accounting, 205, 1700 120, Treasury, , 1700 130, Corporate Tax, , 1700 140, Control And Credit, , 1700 150, Shareholder Services, , 1700 160, Benefits, , 1700 170, Manufacturing, , 1700 180, Construction, , 1700 190, Contracting, , 1700 200, Operations, , 1700 210, IT Support, , 1700 220, NOC, , 1700 230, IT Helpdesk, , 1700 240, Government Sales, , 1700 250, Retail Sales, , 1700 260, Recruiting, , 1700 270, Payroll, , 1700 Without initial spaces after a delimiter: department_id, department_name, manager_id, location_id 10, Administration, 200, 1700 20, Marketing, 201, 1800 30, Purchasing, 114, 1700 40, Human Resources, 203, 2400 50, Shipping, 121, 1500 60, IT, 103, 1400 70, Public Relations, 204, 2700 80, Sales, 145, 2500 90, Executive, 100, 1700 100, Finance, 108, 1700 110, Accounting, 205, 1700 120, Treasury, , 1700 130, Corporate Tax, , 1700 140, Control And Credit, , 1700 150, Shareholder Services, , 1700 160, Benefits, , 1700 170, Manufacturing, , 1700 180, Construction, , 1700 190, Contracting, , 1700 200, Operations, , 1700 210, IT Support, , 1700 220, NOC, , 1700 230, IT Helpdesk, , 1700 240, Government Sales, , 1700 250, Retail Sales, , 1700 260, Recruiting, , 1700 270, Payroll, , 1700
For more Practice: Solve these Related Problems:
- Write a Python program to read a CSV file that may have initial spaces after delimiters, remove those spaces, and print each cleaned row.
- Write a Python script to open a CSV file, trim leading and trailing spaces from every field, and then output the cleaned data to a new file.
- Write a Python program to load a CSV file, strip initial spaces from each field, and then count the number of fields per row to ensure consistency.
- Write a Python script to read a CSV file with extra spaces after delimiters, remove the extra spaces, and then convert the data into a list of dictionaries.
Go to:
Previous: Write a Python program to read a given CSV file as a dictionary.
Next: Write a Python program that reads a CSV file and remove initial spaces, quotes around each entry and the delimiter.
Python Code Editor:
Have another way to solve this solution? Contribute your code (and comments) through Disqus.
What is the difficulty level of this exercise?
Test your Programming skills with w3resource's quiz.
