이번에 현대자동차도 그렇고 기아자동차에서 모빌리티 서비스에 집중하며 데이터 분석과 처리 관련된 직무를 뽑더라고요.
자동차 회사는 돈 많이 주니까(내 1순위) 지원서를 열심히 작성해 지원하게 되었습니다!
1차 - 서류
전형은 서류 - 1차 면접 - 2차 면접 - 최종 합격 이렇게 나와있었어요! 코딩 테스트가 추가되어 코딩테스트를 봤고 그 후기 포스팅이지만 코딩테스트가 없는 줄 알았어요... ㅎㅎ
아무튼! 이제 서류는 어느 정도 붙는 것 같아요. 서류에 엄청난 공을 들인 것은 아니지만 한 2주 정도 조금씩 스트레스받아가며 자소서도 열심히 작성하고 그동안 진행했던 프로젝트 정리한 내용을 가공해 지원서를 작성하였습니다.
자소서 문항은 총 3문항이었고 본인 역량 소개, 기아인 키워드에 따른 자기소개, 앞으로의 커리어 계획에 대해 작성하는 문항이었습니다.
서류 합격 발표는 코딩 테스트 보기 약 9일쯤 전에 났습니다. 회사에 있다가 퇴근하기 약 1시간 전이었는데 확인하고 헙! 하고 놀라다가 사레가 걸렸었죠 ㅋㅋㅋ
2차 - 코딩테스트
두구둥! 오랜만에 보는 합격 소식이라 기분이 좋았습니다!
그리고 아래 오픈 채팅방을 열어주셔서 자유롭게 들어가 채용 관련 질문을 할 수 있었습니다.
그런데 평일 애매한 시간이어서 반차를 내야 하는 상황이었습니다.. ㅠㅠ 안 그래도 없는데 눈치를 보며 반차를 일단 썼습니다.
처음에는 응시 언어에 Java 밖에 없었습니다. 위에 언급한 오픈 채팅방에서 응시 언어와 관련된 질문이 쏟아졌고 며칠 뒤 응시 언어가 추가되었다는 소식에 달려가 보니 C, C++ 이 추가되었더라고요! 직무가 데이터 쪽이라 파이썬 추가는 없냐는 지원자들도 있었지만 딱 잘라 없다고 하더라구요... ㅎㅎ
저는 처음에 알고리즘 공부할 때 C++ 언어로 했어서 그나마 한 일주일 공부하며 자주 사용하는 자료구조를 익혔지만 파이썬으로만 준비해온 지원자들에게는 조금 어려웠겠다 싶었어요.
사실 저도 올해 5월부터는 파이썬으로 알고리즘을 준비해왔어서 C++은 많이 까먹었을 것 같았는데 다행히 많이 까먹지 않았더라고요. 그리고 어떤 언어라도 접근하는 방향은 비슷하니 그동안 문제 해결력이 많이 길러진 이유에서인지 금방 금방 문제를 풀 수 있었습니다.
아무튼 대망의 코딩 테스트 당일! 점심을 많이 먹고 집에 와서 아이스크림도 먹고 접속을 했습니다.
프로그래머스에서 응시를 했고, 구글링 금지, 감독관 연결까지는 하지 않았지만 웹캠, 데스크톱 공유, 스마트폰으로 스트리밍까지 꼼꼼한 관리하에 시험을 보게 되었습니다.
시험은 총 3문제였습니다. (제가 당일에는 도저히 후기를 쓰기 어려울 것 같아서 시험 보자마자 침대에 누워서 시험 본 문제 유형과 내용을 메모해 놨어요 ㅋㅋㅋㅋ 보통 바로 까먹거든요 저는.. ㅎㅎ)
자세히는 누출하면 안 된다고 해서 간략하게 문제 유형만 말씀드리자면,
어레이(벡터) - 정렬, 넣고 빼기
규칙 - 수학적 규칙? 이 문제는 사실 좀 오래 걸렸어요 규칙을 못 찾아서.. ㅎㅎ 여기서도 벡터를 사용했습니다.
나누기와 모듈러 - 이것도 규칙을 찾을 수 있는가와 비슷한 문제
위와 같은 문제였고, 난이도는 2문제는 합쳐서 25분 정도만에 풀고 나머지 한 문제에서 한 한 시간 걸렸습니다. 어렵지 않은 정도라고 할 수 있죠!
오랜만에 코딩 테스트를 보고 기분이 좀 좋아서 방에서 뒹굴다가 저녁으로는 초밥 먹고 금요일이니 신나서 집에서 혼자 놀았습니다 ㅋㅋㅋㅋ
파이썬 언어로는 주로 데이터를 다룰 텐데 도출된 데이터 혹은 중간 데이터를 엑셀 또는 csv 파일로 내보내는 것이 필요할 때가 있습니다. 파이썬에는 csv 모듈이 있어서 간단하게 구현이 가능합니다.
참고로 CSV란 Comma Separated Values로 '쉼표로 구분된 값'이라는 뜻입니다.
1. 파일 읽기
import csv
with open('filename.csv', 'r', newline='', encoding='utf-8-sig') as csv_file:
reader = csv.reader(csv_file, delimiter=',', quotechar='"')
for row in reader:
print(", ".join(row))
#1 csv 모듈을 import 합니다. #2 csv_file 이름으로 'filename.csv' 파일을 'r' 옵션으로 읽습니다. #3 reader라는 객체로 한줄 한 줄 읽어옵니다. #4 각 행은 문자열 리스트로 반환됩니다.
#1 csv 모듈을 import 합니다. #2 header를 정의합니다. #3 csv_file 이름으로 'filename.csv' 파일을 'w' 옵션으로 씁니다. #4 writer라는 객체를 생성합니다. #5 writerow를 통해 헤더를 쓰고, 아래줄에 넣을 값을 입력합니다.
3. 파일 수정
파일 수정은 간단합니다. 'r', 'w' 옵션 자리에 'a'를 넣으면 append의 개념으로 아래 줄에 추가가 됩니다.