Одним из способов будет использование df.replace()
.Вы бы не стали менять числовые столбцы таким образом.
df.replace('[A-Za-z]','N', regex=True).replace('\d','D', regex=True)
Полный пример с числовым столбцом с именем D
, Не числовым с именем N
и TransDetails
.
import pandas as pd
data = '''\
D,N,TransDetails
1,ABC,NEFT-PUNB0315500-JITENDER SING
1,123,NEFT-UTIB0CCH274-VIRENDER KUMA
1,123,NEFT-UTIB0CCH274-SUNITA DEVI
1,123,NEFT-PUNB0315500-AMLASH KUMAR
1,123,NEFT-PUNB0109800-FARIDUDDEN
1,123,NEFT-PUNB0109800-IDREESH
1,123,NEFT-PUNB0315500-BUDDHU
1,123,NEFT-UTIB0CCH274-SAKIL AHAMAD
1,123,NEFT-UTIB0CCH274-NAIM AHAMAD
1,123,NEFT-UTIB0CCH274-SALIM AHAMAD
1,123,NEFT-UTIB0CCH274-NADIM AHAMAD'''
fileobj = pd.compat.StringIO(data) # or 'path/to/csv'
df = pd.read_csv(fileobj)
df = df.replace('[A-Za-z]','N', regex=True).replace('\d','D', regex=True)
print(df)
Возвращает:
D N TransDetails
0 1 NNN NNNN-NNNNDDDDDDD-NNNNNNNN NNNN
1 1 DDD NNNN-NNNNDNNNDDD-NNNNNNNN NNNN
2 1 DDD NNNN-NNNNDNNNDDD-NNNNNN NNNN
3 1 DDD NNNN-NNNNDDDDDDD-NNNNNN NNNNN
4 1 DDD NNNN-NNNNDDDDDDD-NNNNNNNNNN
5 1 DDD NNNN-NNNNDDDDDDD-NNNNNNN
6 1 DDD NNNN-NNNNDDDDDDD-NNNNNN
7 1 DDD NNNN-NNNNDNNNDDD-NNNNN NNNNNN
8 1 DDD NNNN-NNNNDNNNDDD-NNNN NNNNNN
9 1 DDD NNNN-NNNNDNNNDDD-NNNNN NNNNNN
10 1 DDD NNNN-NNNNDNNNDDD-NNNNN NNNNNN