반응형 프로그래밍53 [Flutter] Stream Controller 1. Stream Controller StreamController는 스트림을 제어하는 도구 중 하나입니다. 각각의 StreamController는 'sink'와 'stream'이라는 두 개의 오브젝트를 갖습니다. sink는 스트림에 데이터를 넣어주는(push) 역할을 하며, stream은 데이터 파이프를 타고 넘어오는 데이터를 꺼내는(receive)데 사용합니다. import 'dart:async'; void main() async { // create a StreamController final streamController = StreamController(); // listen to events streamController.stream.listen(print); // push events str.. 프로그래밍/Flutter & Dart 2023. 1. 13. [Sqlite] 월을 이름으로 표현하기 1 -> Jan, 2-> Feb 일부 데이터베이스 프로그램에서 지원하는 함수 중에 to_char라는 함수가 있습니다. 이 함수를 사용하게 되면 숫자로 표시된 월을 이름으로 표현할 수 있습니다. 예를 들어 to_char('2019-01-01', 'Month')라고 표현하면 January라고 출력이 되는 것이죠. 아쉽게도 Sqlite는 to_char의 기능이 없습니다. 하지만 다음과 같이 동일한 효과를 구현할 수는 있습니다. substr('JanFebMarAprMayJunJulAugSepOctNovDec', 1 + 3 * (strftime('%m', '2019-01-01') - 1 ), 3) substr은 문자열중에서 중간의 일부 문자열을 추출할 때 사용하는 함수입니다. 세 개의 인자를 전달받는데 차례대로 '대상문자열', '문자시작위치',.. 프로그래밍 2023. 1. 12. [Sqlite] case문을 이용해서 여러개의 열 만들기 CASE문은 한 번에 한 개의 열 밖에는 리턴할 수 없습니다. 가령 매달의 판매기록을 저장하고 있는 테이블이 있고 이를 각 연도별로 월마다의 매출 기록을 비교하고 싶은 상황을 가정해 봅시다. sales_month | sales 1992-01-01 | 790 1992-02-01 | 539 1992-03-01 | 535 ... 1993-01-01 | 998 1993-02-01 | 568 1993-03-01 | 602 ... 이 경우에 먼저 sales_month에서 달에 해당하는 정보를 추출하여 group by를 이용해 묶어줘야 합니다. 또한 case문을 통해서 sales_month에서의 연도 정보를 추출하고 년도값에 따라서 다른 열에 값을 분배하도록 해야 합니다. 다음과 같이 시도해 볼 수 있습니다. SEL.. 프로그래밍/Sqlite 2023. 1. 11. [Arduino] BLE(HM-10) 제어하기 블루투스를 이용하면 유선을 벗어나 아두이노의 활용 반경을 획기적으로 개선할 수 있습니다. RFID와 BLE모듈을 Arduino에 연결하는 방법에 대해 정리해 보겠습니다. 오늘 활용할 모듈은 다음과 같습니다. - Arduino UNO : 1개 - RFID-RC522 : 1개 - BLE(HM-10) : 1개 먼저 HM-10 BLE 모듈과 Arduino UNO의 연결 회로도는 다음과 같습니다. MH-10은 총 6개의 핀으로 구성되어 있지만 이 중 가운데 네 개의 핀만 연결하여 사용합니다. 다음으로 RFID 모듈을 연결해 보겠습니다. 아래의 배선도를 참고하여 RC-522 모듈과 아두이노를 연결합니다. RC-522은 3.3V의 전압을 필요로 하기 때문에 MH-10 블루투스 모듈과 전원을 분리해서 사용하게 됩니다... 프로그래밍 2023. 1. 11. [Sqlite] YoY, MoM, DoD 분석하기 Sqlite를 이용해서 시계열 분석 중 YoY, MoM, DoD 등 구간비교를 하는 방법에 대해서 정리해 보도록 하겠습니다. 특정 시간 구간의 데이터를 이전 시간의 구간 데이터와 비교함으로써 많은 이점을 얻을 수 있는데 계절성등을 확인할 때 유용하게 사용할 수 있습니다. 실제로 많은 데이터들이 과거 같은시점, 전 달의 같은 날짜 등과 같이 1년, 1달, 혹은 1일 주기로 데이터를 비교하며 증감 추이를 신중하게 관찰하는 것을 알 수 있습니다. 각각을 YoY(Year over Year, 전년 대비 증감률), MoM(Month over Month, 전월 대비 증감률), DoD(Day over Day) 전일 대비 증감률이라는 용어로 구분해서 부르고 있죠. 계절성(seasonality)은 일정한 간격을 두고 규칙.. 프로그래밍/Sqlite 2023. 1. 10. [Sqlite] 날짜 차원(Date Dimension) 테이블 만들기 시계열 분석을 할 때 주의해야 할 것은 중간에 측 데이터가 생기는 상황에서의 대응입니다. 이를 처리하기 위해서 날짜 차원 테이블을 이용하는데 날짜 차원 테이블은 특정 구간 내 모든 날짜별로 값이 저장된 행이 있는 정적 테이블을 의미합니다. 대부분의 데이터베이스에서 기본적으로 내장되어 있는 테이블이지만 sqlite를 이용할 경우 날짜 차원 테이블을 이용하기 위해서는 직접 만들어주는 수 밖에 없습니다. 다음의 쿼리문을 실행시키면 date_dim이라는 이름의 날짜 차원 테이블을 생성할 수 있습니다. 1. 날짜 차원 테이블 생성 쿼리 -- Create a table to permanently store the output CREATE TABLE date_dim AS -- Initiate the recursive.. 프로그래밍/Sqlite 2023. 1. 6. [Sqlite] 이동평균(moving avg) 계산하기 데이터베이스를 시계열 분석을 하게 되면 이동평균을 계산하는 상황이 많이 발생합니다. 이동평균을 구하면 데이터의 노이즈를 줄여주어 경향성을 파악하는데 도움이 많이 되기 때문이죠. 다음은 Postgre에서 이동평균을 구하는 하나의 예제 sql문입니다. 이를 sqlite 문법을 이용해서 구현할 때 어떤 차이점이 있는지 확인해 보도록 하겠습니다. 1. Postgre SELECT a.sales_month ,a.sales ,avg(b.sales) as moving_avg ,count(b.sales) as records_count FROM sales a JOIN sales b on a.kind_of_business = b.kind_of_business and b.sales_month between a.sales_mo.. 프로그래밍/Sqlite 2023. 1. 6. [sqlite] date_part 기능 사용하기 Postgre와 같은 데이터베이스에서 날짜 및 시간 데이터 조작을 위한 명령어 중 date_part라는 명령어가 있습니다. 예를 들어 판매날짜가 저장되어 있는 sales_month라는 열의 데이터에서 연도 정보를 추출하기 위해서 다음과 같이 사용합니다. SELECT date_part('year', sales_month) as sales_year; 하지만 sqlite는 위와 같이 date_part와 같은 명령어가 없습니다. 하지만 위와 같은 결과를 출력하기 위해서 아래와 같이 작성해 줄 수 있습니다. SELECT strftime('%Y-01-01', sales_month) as sales_year; 이렇게 작성할 경우 sales_year에 연도를 제외한 나머지 월, 일 정보가 1월 1일로 변경된 날짜가 저.. 프로그래밍/Sqlite 2023. 1. 5. [Flutter] for와 forEach Flutter에서 가장 대표적으로 사용하는 반복문은 for와 forEach입니다. 각각 외부반복, 내부반복으로 구분합니다. 문법에 대해서 간단히 정리해 보면 다음과 같습니다. 1에서 6까지 숫자가 차례대로 저장되어 있는 리스트의 각 원소를 출력하는 코드를 작성해 보도록 하겠습니다. 구현된 코드는 다음과 같습니다. void main() { final lists = [1, 2, 3, 4, 5, 6]; for (int i = 0; i < lists.length; i++) { print('for loop: ${lists[i]}'); } lists.forEach((e){ print('forEach loop: $e'); }); } 가장 먼저 1에서 6까지 원소로 이루어진 lists 리스트를 정의합니다. for문에서.. 프로그래밍/Flutter & Dart 2023. 1. 5. [Flutter] Cascade Operator 오늘은 Cascade Operator에 대해서 알아보도록 하겠습니다. 계단식 표기법으로도 불립니다. Cascade Operator를 사용하면 동일 객체에서의 일련의 작업을 보다 깔끔하게 표현할 수 있습니다. 다음과 같이 정의된 User class가 있다고 가정해 봅시다. class User{ String name = ''; int age = 0; } void main() { User user = User(); user.name = 'juhan'; user.age = 23; User user1 = User() ..name = 'juhan' ..age = 23; } User class는 하위에 name과 age라는 두 개의 속성을 가지고 있습니다. User class를 이용해서 새로운 인스턴스를 만들고 새로.. 프로그래밍/Flutter & Dart 2023. 1. 5. [Flutter] Future Builder 함수를 통해서 어떤 값을 리턴할 때 우리는 기본적으로 즉각적으로 값은 반환하는 상황을 주로 사용하였습니다. 하지만 애플리케이션 외부로부터 데이터를 전달받는 상황이라면 함수가 실행되고 나서 네트워크 문제등에 의해서 값을 바로 출력할 수 없는 경우가 발생합니다. 이 때 Future Builder를 이용해서 값을 받을 수 있습니다. Future Builder를 이용하면서 Future 타입의 데이터를 다루게 되는데 말 그대로 미래의 어느 한 시점(in the future)에 얻게 되는 데이터를 의미합니다. 다음의 소스코드를 통해서 값이 출력되는 과정을 살펴보도록 하겠습니다. 우리가 흔히 사용하는 함수는 함수가 호출되는 즉시 값을 반환하고 반환된 값을 변수에 저장한 뒤 화면에 출력하는 방법으로 사용됩니다. (ge.. 프로그래밍/Flutter & Dart 2023. 1. 5. [sqlite] csv로부터 데이터베이스 만들기(windows) csv 파일을 sqlite 데이터베이스 파일로 변환하기 위한 방법은 다음과 같습니다. 먼저 실행창에 'PowerShell'을 검색하여 'Windows PowerShell'을 엽니다. csv 파일이 있는 폴더로 이동합니다. 예를 들어 sales.csv 라는 이름의 csv 파일을 mydatabase.db라는 데이터베이스를 만들고 그 안에 table1이라는 이름으로 저장한다고 하면 다음과 같이 명령어를 입력합니다. sqlite3 mydatabase.db ".mode csv" ".import sales.csv table1" ".exit" 명령어를 실행하면 cvs가 위치한 폴더에 mydatabase.db 라는 데이터베이스 파일이 생성되고 SQLite Expert Personal 프로그램을 통해서 데이터베이스를 열.. 프로그래밍/Sqlite 2023. 1. 5. 이전 1 2 3 4 5 다음 반응형