컴퓨터 102

Python (16) - TTS와 STT를 구현하자 (pyttsx3, Speech Recogition)

군대에서 기가지니라는 인공지능 스피커를 처음 사용하였습니다. 최근에 인공지능 스피커에 대하여 관심을 가지기 시작하였는데 여기에서 핵심기술이 텍스트와 음성 간의 관계라고 생각합니다. 두 관계를 해결해야지 사람과 기계가 소통할 수 있기 때문입니다. 그래서 이번에는 사람과 기계가 소통하는 방법 TTS와 STT에 대하여 알아보겠습니다. STT (Speech to Text) "기가지니?"라고 우리가 말하면 기가지니는 "네?"라고 반응합니다. 어떻게 기가지니라고 말하는 것을 컴퓨터가 알아들었을까요? 이것은 STT라는 기술을 이용하여 음성을 분석하여 텍스트로 바꾸어 주기 때문입니다. 발음마다 매질이 달라 일일이 분석하여 해당 소리를 낼 수도 있지만 해당 과정은 몹시 어렵습니다. 그래서 파이썬에 패키지를 이용하려고 합..

컴퓨터/Python 2023.05.10

MySQL (13) - 프로시저(Procedure)와 함수(Function)

간단하게 CRUD만 사용하는 경우에는 SQL을 깊게 사용하지 않지만, 전문적으로 DB를 운영하기 위해서는 결국 함수형으로 관리하는 것이 필수입니다. SQL에는 함수만 있지 않고 프로시저가 있습니다. 이번에는 해당 개념에 대하여 알아보려고 합니다. 함수 (Function) 데이터베이스에서 함수는 일반적인 프로그래밍언어에서 함수의 역할과 동일합니다. 입력값을 받아 특정한 작업을 수행하고 결과값을 출력하는 구조로 되어있습니다. 함수는 특정 작업을 수행하고 그 결과를 반환하여 DML 및 SELECT를 사용하는 쿼리문 안에서 표현식으로 사용될 수 있습니다. 함수는 다음과 같은 특징을 가지고 있습니다. 함수에서 입력값을 받아 처리하고 해당 결과값을 반환합니다. 함수 호출 문에서 반환된 값으로 사용할 수 있습니다. ..

컴퓨터/MySQL 2023.05.01

Python (15) - 파이썬 가상환경을 만들자 (venv)

한 프로그래밍 언어로 여러 가지 작업을 하다 보면 패키지의 충돌 등 다양한 문제가 생길 수 있습니다. 특히 파이썬 같은 경우에는 A라는 프로젝트를 돌리기에 패키지가 많은 오류를 일으킵니다. 이런 방법을 해결하기 위한 한 가지의 수단으로 가상환경을 이용해보도록 하겠습니다. 가상환경이 필요한 이유 위에서 말한 것과 같이 여러 가지 작업을 하다 보면 패키지의 충돌이 일어날 수 있습니다. 프로젝트마다 필요한 라이브러리나 패키지의 버전이 다르기 때문에 해당 사건이 일어날 수 있습니다. 이것을 의존성 분리라고 합니다. 가상환경을 통하여 의존성 충돌을 피하고, 각 프로젝트를 독립적으로 관리할 수 있습니다. 이를 통하여 효율적으로 프로젝트를 관리할 수 있으며 이는 프로그램 제작 후 배포 시에 용이합니다. 위의 두 사진..

컴퓨터/Python 2023.04.15

컴퓨터 고치기 - 새 파티션을 만들거나 기존 파티션을 찾을 수 없습니다

4월5일 친구가 노트북을 바꿔 윈도우10을 설치해주었습니다. 처음에는 USB인식이 안 되다가 포트 변경을 통하여 USB 인식이 잘되었고 윈도우10를 설치하던 중 아래와 같은 에러를 마주하게 되었습니다. 새 파티션을 만들거나 기존 파티션을 찾을 수 없습니다 ※ 이번 글에는 원격으로 해결해서 사진을 거의 못 찍었습니다. 대상 컴퓨터 MSI Sword GF76 B13VFK (SSD 512GB) i7-13세대, 16GB RAM, RTX 4060 window10 (설치 중) 해결 방법 제가 해결한 방식은 CMD를 이용하여 하드를 포맷한 재부팅 후 실행하였더니 됏습니다. 순서는 다음과 같습니다. 1. Shift + F10으로 CMD 창을 엽니다. 2. 그다음 아래의 명령 순서를 따라가도록 합시다. diskpart ..

MySQL (12) - 집계함수에 대하여 알아보자 (COUNT, SUM, AVG, MIN, MAX)

SQL을 사용하는 경우 테이블의 최솟값, 합계 등 정보가 필요한 경우가 있습니다. 그럴 때 집계함수라는 것을 활용합니다. 5가지의 집계함수에 대하여 알아보겠습니다. 집계함수 집계함수(Aggregate Function)란 DB에서 특정 칼럼의 값들을 모아서 계산하는 함수입니다. 이에 따른 특징으로 입력이 여러 개의 row를 가지고 출력이 하나의 결과를 만듭니다. 집계 함수를 이용하여 데이터의 요약 정보를 쉽게 구할 수 있습니다. 예제 테이블 class name price score 1 minji 5500 80 2 sanggyu 1000 2000 3 younga 2500 100 COUNT SELECT COUNT(*) --2 FROM mytable WHERE price > 2000; COUNT 함수는 특정 칼..

컴퓨터/MySQL 2023.04.05

MySQL (11) - 내장함수를 이용하여 숫자를 다뤄보자

SQL을 다룰 때 문자만큼이나 숫자 형식도 많이 다루게 됩니다. 문자열 내장함수에 이어 숫자를 조작하는 내장함수를 알아보도록 하겠습니다. ※ 함수 설명을 중심으로 내용을 진행합니다. ※ 제가 자주 사용한 함수는 ★로 표시하였습니다. 숫자 함수정리 ABS (★) SELECT ABS(-1004) -- 1004 FROM DUAL; ABS 함수는 절댓값으로 반환하는 함수입니다. 해당 예제에서는 1004로 반환합니다. SIGN SELECT SIGN(1004) --1 FROM DUAL; SIGN 함수는 숫자가 양수인 경우에는 1 음수 일때는 -1을 반환하며, 0일 때는 0을 반환합니다. 위의 예제에는 1을 반환합니다. POW, SQRT (★) SELECT POW(3,2), SQRT(16) -- 9, 4 FROM D..

컴퓨터/MySQL 2023.04.02

파일포맷 - XML과 JSON에 대하여 알아보자.

이전에, 블로그에 XMLHttpRequest 객체에 대하여 작성한 적이 있었습니다. XML 파일을 이용하여 데이터를 받았습니다. XML만큼 전송에서 많이 쓰는 JSON 파일도 있습니다. 두 가지 문법과 방식에 차이에 대하여 알아보도록 하겠습니다. XML (eXtensible Markup Language) Kim Narae Lee/firstName> Ujin Kim Daewu XML은 데이터를 저장하고 전달하기 위해 만들어졌으며 저장되는 데이터의 구조를 표현하기 위한 언어입니다. HTML의 문법과 매우 비슷한 마크업 언어입니다. HTML과 차이점은 XML태그는 HTML태그와 같이 미리 정의 되어있지 않으며 사용자가 직접 정의할 수 있습니다. 이것은 좋은 확장성을 보입니다. 데이터를 보여주는 목적이 아닌 데..

MySQL (10) - Transaction(트랜잭션)에 대하여 알아보자

DB 서버를 운영하다 보면 종종 데이터를 잘못 입력하여 서버가 꼬이는 경우가 있습니다. DB에는 트랜잭션이라는 개념이 있습니다. 트랜잭션을 제어하는 경우 어느 정도 해당 문제를 해결할 수 있습니다. 트랜잭션이란? 트랜잭션(Transaction)은 DB의 상태를 변환시키는 작업 단위 혹은 한 번에 모두 수행하여야 하는 연산들의 모음을 말합니다. 한마디로 쪼갤 수 없는 작업의 최소 단위를 말합니다. SQL에 자주 사용하는 4가지의 쿼리문이 있습니다. (SELECT, INSERT, UPDATE, DELETE) 위의 쿼리중 1가지만 사용하는 경우도 작업의 단위가 될 수 있습니다. 하지만 이것에 벗어나 예를 들어 게시글을 작성하고, 업로드하며, 마지막으로 다시 게시판에 조회하는 경우 이것을 묶어 작업하는 것도 단..

컴퓨터/MySQL 2023.03.23

JavaScript (5) - 서버 시간을 가져오자 (XMLHttpRequest)

수강 신청을 할 때 타임시커등 다양한 프로그램을 이용하여 서버 시간을 가져옵니다. 수강 신청 때 시간 편차에 예민하기 때문에 서버 시간을 알아 오는 것이 중요합니다. 자바스크립트를 이용하여 간단하게 서버 시간을 가져올 수 있습니다. XMLHttpRequest XMLHttpRequest 객체는 서버로부터 XML 데이터를 가져오는 데 사용합니다. 해당 객체를 이용하여 웹 페이지 로딩이 완료된 후에도 서버에 데이터를 요청하거나 서버로부터 데이터를 전송받을 수 있습니다. 여기서 XML은 extensible markup language의 약자로 HTML과 같은 마크업 언어입니다. HTML과 다른 점은 XML은 데이터를 저장하고 전송하는 목적으로 만들어져 있고, 사용자가 직접 정의할 수 있는 특징을 가지고 있습니다..

MySQL (9) - 내장함수를 이용하여 글자를 다뤄보자

예전에 select절을 이용하여 데이터를 불뤄 오는 방법을 다뤘습니다. 데이터를 그대로 가지고 오는 것이 아니고 가공해서 가져오는 것도 필요하다는 것을 알았습니다. where절을 이용하여 데이터의 일부를 가져오는 방법 등을 더 범위 있는 사용을 위해 이번에는 해당 함수들을 설명하려고 합니다 ※ 함수 설명을 중심으로 내용을 진행합니다. ※ 제가 자주 사용한 함수는 ★로 표시하였습니다. 문자열 함수정리 LIKE (★★★) -- sam문자가 포함된 값을 모두 조회한다. SELECT * FROM mytable WHERE comp LIKE '%sam%'; -- sam문자로 시작하는 값을 모두 조회한다. SELECT * FROM mytable WHERE comp LIKE 'sam%'; -- 삼으로 시작하는 3글자를..

컴퓨터/MySQL 2023.03.16