Java 67

[SPRING] EXCEL 업로드하여 데이터 처리하기 #1

엑셀 데이터를 파싱하여 Database를 업데이트할 수 있도록 해달라는 요청사항에 따라 개발을 수행하게 되었다. 까먹지 않기 위해 포스팅을 작성해본다. 시나리오 사이트의 장기 미사용자에 대해 문자메시지를 발송 후 발송된 시점으로 Database 업데이트 1. 웹페이지에서 파일을 등록하고 업데이트 버튼을 클릭 2. 서버에서 엑셀 파일 파싱 3. Dabase에 사용자 존재여부 확인 4. 존재한다면 database update 5. update된 사용자 수 페이지로 전달 예제로 아래와 같은 엑셀을 전달받을 경우 처리하는 방법에 대해 작성하겠다. pom.xml 필요한 라이브러리는 아래와 같다. 파일의 type을 체크하여 에러를 발생시키기 위해 apache tika 라이브러리를 추가했다. org.apache.po..

[백준] 14425번:문자열 집합

문제 총 N개의 문자열로 이루어진 집합 S가 주어진다. 입력으로 주어지는 M개의 문자열 중에서 집합 S에 포함되어 있는 것이 총 몇 개인지 구하는 프로그램을 작성하시오. 입력 첫째 줄에 문자열의 개수 N과 M (1 ≤ N ≤ 10,000, 1 ≤ M ≤ 10,000)이 주어진다. 다음 N개의 줄에는 집합 S에 포함되어 있는 문자열들이 주어진다. 다음 M개의 줄에는 검사해야 하는 문자열들이 주어진다. 입력으로 주어지는 문자열은 알파벳 소문자로만 이루어져 있으며, 길이는 500을 넘지 않는다. 집합 S에 같은 문자열이 여러 번 주어지는 경우는 없다. 출력 첫째 줄에 M개의 문자열 중에 총 몇 개가 집합 S에 포함되어 있는지 출력한다. 풀이 처음에는 문자열 집합 S의 문자열 일부와 일치하는 문자열이면 카운트를..

백준 2023.08.17

[백준] 18870번:좌표 압축 - JAVA

문제 수직선 위에 N개의 좌표 X1, X2, ..., XN이 있다. 이 좌표에 좌표 압축을 적용하려고 한다. Xi를 좌표 압축한 결과 X'i의 값은 Xi > Xj를 만족하는 서로 다른 좌표 Xj의 개수와 같아야 한다. X1, X2, ..., XN에 좌표 압축을 적용한 결과 X'1, X'2, ..., X'N를 출력해보자. 입력 첫째 줄에 N이 주어진다. 둘째 줄에는 공백 한 칸으로 구분된 X1, X2, ..., XN이 주어진다. 출력 첫째 줄에 X'1, X'2, ..., X'N을 공백 한 칸으로 구분해서 출력한다. 풀이 좌표 압축이란 탐색해야 할 좌표가 많을 경우 불필요한 좌표들을 지우는 방식을 말한다. 예를 들어 탐색 알고리즘을 사용할 때 데이터의 양이 많을 경우 불필요한 좌표들을 지우고 정점의 좌표들만..

백준 2023.08.17

[백준] 1181번:단어 정렬 - JAVA

문제 알파벳 소문자로 이루어진 N개의 단어가 들어오면 아래와 같은 조건에 따라 정렬하는 프로그램을 작성하시오. 길이가 짧은 것부터 길이가 같으면 사전 순으로 단, 중복된 단어는 하나만 남기고 제거해야 한다. 입력 첫째 줄에 단어의 개수 N이 주어진다. (1 ≤ N ≤ 20,000) 둘째 줄부터 N개의 줄에 걸쳐 알파벳 소문자로 이루어진 단어가 한 줄에 하나씩 주어진다. 주어지는 문자열의 길이는 50을 넘지 않는다. 출력 조건에 따라 정렬하여 단어들을 출력한다. 풀이 방장의 풀이순서는 다음과 같다. 1. String 배열에 담음 2. 중복 제거 (Stream 사용) 3. String 길이 비교 (Comparator 사용) 4. 개수가 같다면 사전순으로 정렬 (String compareTo 사용) impor..

백준 2023.08.16

[백준] 11650번:좌표 정렬하기 -JAVA

문제 2차원 평면 위의 점 N개가 주어진다. 좌표를 x좌표가 증가하는 순으로, x좌표가 같으면 y좌표가 증가하는 순서로 정렬한 다음 출력하는 프로그램을 작성하시오. 입력 첫째 줄에 점의 개수 N (1 ≤ N ≤ 100,000)이 주어진다. 둘째 줄부터 N개의 줄에는 i번점의 위치 xi와 yi가 주어진다. (-100,000 ≤ xi, yi ≤ 100,000) 좌표는 항상 정수이고, 위치가 같은 두 점은 없다. 출력 첫째 줄부터 N개의 줄에 점을 정렬한 결과를 출력한다. 풀이 Comparator 인터페이스를 활용하여 정렬 compare 메서드 첫 번째 원소가 두 번째 원소보다 클 경우 자리를 변경 [0]배열을 비교, 같을 경우에는 [1]배열의 원소를 비교하여 정렬 import java.io.BufferedR..

백준 2023.08.16

Google SpreadSheet API와 JAVA 연동하기 #2

https://many.tistory.com/11에서 google에 대한 설정을 마쳤다. 이번 글에서는 java에서 코드 작성 후 api 연동까지 수행해보겠다. 방장은 maven spring boot 프로젝트로 라이브러리를 추가하여 개발을 수행하였다. 1. pom.xml 필요한 라이브러리들을 추가했다. com.google.api-client google-api-client 1.25.0 com.google.oauth-client google-oauth-client 1.34.1 com.google.apis google-api-services-sheets v4-rev612-1.25.0 com.google.oauth-client google-oauth-client-java6 1.21.0 com.google.oa..

Google SpreadSheet API와 JAVA 연동하기 #1

업무사항 중에 통계 데이터를 google sheet에 전송하여 사업팀에서 즉각적으로 확인할 수 있게 해달라는 요청에 따라 연동작업을 수행하게 되었다. 준비(Google) 1. google cloud 접속 에 google spreadsheet api를 검색 후 google cloud에 접속한다. 2. 프로젝트 생성 google 로고 바로 옆에 project를 클릭 후 새 프로젝트를 생성한다. 해당 프로젝트로 이동 후 API 및 서비스 사용 설정을 클릭하여 Google Sheets API를 사용으로 변경한다. 3. 서비스 계정 생성 좌측 사용자 인증 정보 탭을 클릭 후 사용자 인증 정보 만들기를 클릭, 서비스 계정을 생성한다. 방장은 google-spread-sheet라는 계정명으로 생성했다. 생성된 계정의..