How to Skip First Rows in Pandas read_csv and skiprows?
Do you need to skip rows while reading CSV file with read_csv in Pandas? If so, this article will show you how to skip first rows of reading file.
Method read_csv
has parameter skiprows
which can be used as follows:
(1) Skip first rows reading CSV file in Pandas
pd.read_csv(csv_file, skiprows=3, header=None)
(2) Skip rows by index with read_csv
pd.read_csv(csv_file, skiprows=[0,2])
Lets check several practical examples which will cover all aspects of reading CSV file and skipping rows.
To start lets say that we have the next CSV file:
!cat '../data/csv/multine_header.csv'
CSV file with multiple headers (to learn more about reading a CSV file with multiple headers):
Date,Company A,Company A,Company B,Company B
,Rank,Points,Rank,Points
2021-09-06,1,7.9,2,6
2021-09-07,1,8.5,2,7
2021-09-08,2,8,1,8.1
Step 1: Skip first N rows while reading CSV file
First example shows how to skip consecutive rows with Pandas read_csv
method.
There are 2 options:
- skip rows in Pandas without using header
- skip first N rows and use header for the DataFrame - check Step 2
In this Step Pandas read_csv method will read data from row 4 (index of this row is 3). The newly created DataFrame will have autogenerated column names:
df = pd.read_csv(csv_file, skiprows=3, header=None)
This will result into:
0 | 1 | 2 | 3 | 4 |
---|---|---|---|---|
2021-09-07 | 1 | 8.5 | 2 | 7.0 |
2021-09-08 | 2 | 8.0 | 1 | 8.1 |
Step 2: Skip first N rows and use header
If parameter header
of method read_csv
is not provided than first row will be used as a header. In combination of parameters header
and skiprows
- first the rows will be skipped and then first on of the remaining will be used as a header.
In the example below 3 rows from the CSV file will be skipped. The forth one will be used as a header of the new DataFrame.
df = pd.read_csv(csv_file, skiprows=3)
2021-09-07 | 1 | 8.5 | 2 | 7 |
---|---|---|---|---|
2021-09-08 | 2 | 8 | 1 | 8.1 |
Step 3: Pandas keep the header and skip first rows
What if you need to keep the header and then the skip N rows? This can be achieved in several different ways.
The most simple one is by builing a list of rows which to be skipped:
rows_to_skip = range(1,3)
df = pd.read_csv(csv_file, skiprows=rows_to_skip)
result:
Date | Company A | Company A.1 | Company B | Company B.1 |
---|---|---|---|---|
2021-09-07 | 1 | 8.5 | 2 | 7.0 |
2021-09-08 | 2 | 8.0 | 1 | 8.1 |
As you can see read_csv
method keep the header and skip first 2 rows after the header.
Step 4: Skip non consecutive rows with read_csv
by index
Parameter skiprows
is defined as:
Line numbers to skip (0-indexed) or number of lines to skip (int) at the start of the file.
So to skip rows 0 and 2 we can pass list of values to skiprows
:
df = pd.read_csv(csv_file, skiprows=[0,2])
Unnamed: 0 | Rank | Points | Rank.1 | Points.1 |
---|---|---|---|---|
2021-09-07 | 1 | 8.5 | 2 | 7.0 |
2021-09-08 | 2 | 8.0 | 1 | 8.1 |