How To Remove Multiple Headers From Dataframe And Keeps Just The First Python
I'm working with a csv file that presents multiple headers, all are repeated like in this example: 1 2 3 4 0 POSITION_T PROB ID 1
Solution 1:
Filtering out by field value:
df = pd.read_table('yourfile.csv', header=None, delim_whitespace=True, skiprows=1)
df.columns = ['0','POSITION_T','PROB','ID']
del df['0']
# filtering out the rows with `POSITION_T` value in corresponding columndf = df[df.POSITION_T.str.contains('POSITION_T') == False]
print(df)
The output:
POSITION_T PROB ID
1 2.385 2.0 1
3 3.074 6.0 3
4 6.731 8.0 4
6 12.508 2.0 1
7 12.932 4.0 2
8 12.985 4.0 2
Solution 2:
This is not ideal! The best way to deal with this would be to handle it in the file parsing.
mask = df.iloc[:, 0] == 'POSITION_T'
d1 = df[~mask]
d1.columns = df.loc[mask.idxmax].values
d1 = d1.apply(pd.to_numeric, errors='ignore')
d1
POSITION_T PROB ID
1
1 2.385 2.0 1
3 3.074 6.0 3
4 6.731 8.0 4
7 12.508 2.0 1
8 12.932 4.0 2
9 12.985 4.0 2
Solution 3:
past_data=pd.read_csv("book.csv")
past_data = past_data[past_data.LAT.astype(str).str.contains('LAT') == False]
print(past_data)
- Replace the CSV (here: book.csv)
- Replace your variable names (here: past_data)
- Replace all the LAT with your any of your column name
- That's All/ your multiple headers will be removed
Post a Comment for "How To Remove Multiple Headers From Dataframe And Keeps Just The First Python"