일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 |
- 오답노트
- Kubernetes
- 러닝
- GitHub
- Linux
- DSEC
- 중식
- 맛집
- 정보처리기사
- 2021
- Run The Bridge
- Podman
- 달리기
- 하체
- 유산소
- 소모임
- Python
- 건대입구역
- 자전거
- 한강
- Shell
- 힐링
- 성수대교
- 대전
- zabbix
- 뚝섬유원지
- 대구
- 10km
- Grafana
- docker
- Today
- Total
Run The Bridge
(Pandas) 특정 횟수를 Count한 다음 각 Row에 값 넣기 본문
1 |
attack_list = list(np.array(train_dataset['Attack_Name'].tolist())) |
Attack_Name을 list로
변환 후 attack_list에 담는다.
다음과 같은 형태로 이루어져있다.
1 2 3 |
attack_number = [] for i in attack_list: attack_number.append(i[:6]) |
Unique값으로 쓸 수 있는 앞에 (nnnn)을 parsing한다.
1 2 3 |
count_IP = [] for i in attack_number: count_IP.append(len(list(df_train[df_train['Attack_Name'].str.contains(i)]['Attack_IP'].unique().tolist()))) |
Count_IP라는 빈 list를 생성한 뒤, attack_number을 i에 담아준다.
그 후 str.contains()를 사용하여, attack_number로 시작하는 숫자를 모두 뽑고, Attack_IP의 unique값들을 list로 생성한다.
그러면 다음과 같이 숫자들이 count 되는것을 볼 수 있다.
1 2 |
# Column에 입력 train_dataset['Attack_IP_Count'] = count_IP |
그 다음 DataFrame에 Column을 생성하고 값을 넣어주면된다.
Project하면서 생각보다 괜찮은 코딩인거 같아서 review를 해보았는데, 생각보다 표현하기가 어려운거같다.
더 쉬운방법이 있으면 댓글로 알려주면 감사하겠습니다.
감사합니다. Thank you!
'Python > ※Pandas Tip' 카테고리의 다른 글
(Pandas) 생각보다 자주 쓰는 코드 (0) | 2020.11.22 |
---|---|
(Pandas) 요약정보에 임의 labeling 후 본 DataFrame에 label 달기 (0) | 2020.11.22 |
(Pandas) 각 Column들의 횟수가 다양하게 존재할 때 횟수별로 Count 후 값 넣기 (0) | 2020.11.22 |
(Pandas) Column 추가와 원하는 곳에 생성하기 (0) | 2020.11.22 |
(Pandas) 인덱스 분리 후 각 Column 생성하기 (0) | 2020.11.22 |