java.lang.IllegalArgumentException: Malformed escape pair at index 해결
·
Framework & Runtime/SpringBoot
Error creating bean with name 'postConstructInitializeBean': Invocation of init method failed; nested exception is java.lang.IllegalArgumentException: Malformed escape pair at index redis 서버와 연동을 테스트 하려던 중 발생한 오류이다. lettuce 에서 뿜어낸 에러 같은데, RedisClient 를 create 할 때 입력해주는 비밀번호에 있는 특정 문자를 제대로 입력 받지 못하는 것 같다. 로 되어 있는 코드를 URLEncoder.encode() 를 이용하여 주었고, UTF-8 로 인코딩 하도록 했다. 이후 에러가 해결되었다. 필자의 경우에는 sprin..
갤럭시 S22+ 삼성단독 컬러 사전구매가 너무 하고 싶었던 개발자의 개발
·
일상다반사/개발
갤럭시 S22+ 기기의 삼성 갤럭시 스토어 단독 컬러인 크림 색상을 너무 갖고싶었지만 매진이 되는 바람에 크롤링 프로그램을 만들어서 주기적으로 확인해주는 프로그램을 만들었었습니다 :) 크롤링은 처음 해보는 것이었는데, selenium 을 통해서 개발을 쉽게 할 수 있었습니다. https://github.com/kotlin-telegram-bot/kotlin-telegram-bot 를 활용해서 텔레그램 봇 또한 연동해보려 하였지만 생각보다 빠르게 구매를 하게 되어서, 거기까진 가지 않게 되었습니다! 소스코드는 아래에 있으며, 크게 뜻을 두고 작성한 코드는 아니라서, 코드가 지저분할 수 있습니다. 성공 사진 갤럭시 캠퍼스 스토어와 공식 스토어 각각의 페이지에서 xpath 를 따왔고, 주기적으로 그 텍스트를 ..
(백준/Kotlin) 1764번 : 듣보잡
·
CodingTest
난이도: Silver 4 프로그래밍 언어: Kotlin 문제명: 듣보잡 푼일자: 2022년 1월 주소: https://www.acmicpc.net/problem/1764 문제풀기 fun main() = with(System.`in`.bufferedReader()) { val set = mutableSetOf() val list = mutableListOf() val (N, M) = readLine().split(' ').map { it.toInt() } repeat(N) { set.add(readLine()) } repeat(M) { val s = readLine() if (set.contains(s)) list.add(s) } val sb = StringBuilder().appendLine(list.s..
(백준/Kotlin) 1302번 : 베스트셀러
·
CodingTest
난이도: Silver 4 프로그래밍 언어: Kotlin 문제명: 베스트셀러 푼일자: 2022년 1월 주소: https://www.acmicpc.net/problem/1302 문제풀기 fun main() = with(System.`in`.bufferedReader()) { val map = mutableMapOf() repeat(readLine().toInt()) { val book = readLine() map[book] = (map[book] ?: 0) + 1 } print(map.toSortedMap().maxByOrNull { it.value }!!.key) }
(백준/Kotlin) 6588번 : 골드바흐의 추측
·
CodingTest
난이도: Silver 1 프로그래밍 언어: Kotlin 문제명: 패션왕 신해빈 푼일자: 2022년 1월 주소: https://www.acmicpc.net/problem/6588 문제풀기 fun main() = with(System.`in`.bufferedReader()) { val sb = StringBuilder() val prime = BooleanArray(1000001) for (i in 2..1000000) if (!prime[i]) for (j in i * 2..1000000 step(i)) prime[j] = true while (true) { val n = readLine().toInt() var exists = false if (n == 0) break for (i in 3..n) if ..
(백준/Kotlin) 9375번 : 패션왕 신해빈
·
CodingTest
난이도: Silver 3 프로그래밍 언어: Kotlin 문제명: 패션왕 신해빈 푼일자: 2022년 1월 주소: https://www.acmicpc.net/problem/9375 문제풀기 split 부분을 StringTokenizer 로 대체하면 시간이 많이 줄어드니 해당 방법도 좋습니다. import java.util.* fun main() = with(System.`in`.bufferedReader()) { val sb = StringBuilder() repeat(readLine().toInt()) { _ -> val map = HashMap() repeat (readLine().toInt()) { val kind = readLine().split(' ')[1] map[kind] = if (map.co..
(백준/Kotlin) 1159번 : 농구 경기
·
CodingTest
난이도: Bronze 2 프로그래밍 언어: Kotlin 문제명: 농구 경기 푼일자: 2022년 1월 주소: https://www.acmicpc.net/problem/1159 문제풀기 몇분만에 푼 문제였습니다. fun main() = with(System.`in`.bufferedReader()) { // 농구 경기 val arr = IntArray(26) val sb = StringBuilder() repeat(readLine().toInt()) { arr[readLine()[0].code - 0x61]++ } arr.forEachIndexed { index, i -> if (i >= 5) sb.append((index + 0x61).toChar()) } print(if (sb.toString().isEm..
[Kotlin] Unexpected error occurred in scheduled task (how to solve or fix)
·
Framework & Runtime/SpringBoot
해당 에러가 발생했을 때 검색을 해보니, Serializable 를 implements 하라고 합니다. 하지만 인텔리제이는 이 인터페이스를 불러올 줄을 모르고 있습니다. 위 에러 메세지에 힌트가 있습니다. java.io.Serializable 에러가 해결되었습니다 :)
(백준/Kotlin) 5430번 : AC
·
CodingTest
난이도: Gold 5 프로그래밍 언어: Kotlin 문제명: AC 푼일자: 2021년 11월 주소: https://www.acmicpc.net/problem/5430 문제풀기 문제 자체에는 크게 어려운 내용이 없어서 코드로 바로 작성해 보았습니다. import java.util.* import kotlin.collections.ArrayDeque fun main() = with(System.`in`.bufferedReader()) { // AC val dq = ArrayDeque() val sb = StringBuilder() var st: StringTokenizer val T = readLine().toInt() repeat(T) { _ -> run block@{ val p = readLine().t..
[Querydsl] n시간 이전 데이터 삭제
·
Language/Kotlin
@Transactional fun exampleMethod(): Long { var date = LocalDateTime.now() date = date.minusHours(1) return queryFactory .delete(table_name) .where(table_name.updatedAt.lt(date)) .execute() } 위 코드는 아래와 같이 작동됩니다. 현재 시간이 2021년 11월 20일 10시 5분 이라면, DELETE FROM `table_name` WHERE `table_name`.updatedAt < '2021-11-20 09:05:00' 위와 같은 쿼리문이 작성되는 것입니다. 쿼리 진행 후 삭제가 된 데이터의 갯수를 리턴하도록 되어 있습니다.