[Python] 패키지란?
목차 모듈이란? 모듈의 정의 모둘 생성 __name__ if __name__ == "__main__": 패키지란? 엔트리 포인트(entry point) 패키지 패키지 관리 시스템 패키지 생성 엔트리 포인트(entry point) 엔트리 포인트(entry point)는 프로그램이 실행될 때 실행되는 첫 번째 코드 줄입니다. main 함수 또는 'main'은 종종 많은 프로그래밍 언어에서 엔트리 포인트(entry point) 역할을 합니다. 그러나 Python에는 C, C++ 또는 Java와 같은 다른 프로그래밍 언어와 같은 기본 제공 main 기능이 없습니다. 대신 Python은 특수 변수 __name__을 사용하여 스크립트가 기본 프로그램으로 실행되고 있는지 또는 다른 스크립트에 모듈로 가져오고 있는지를..
2023.05.06
[Python] 모듈이란?
목차 모듈이란? 모듈의 정의 모둘 생성 __name__ if __name__ == "__main__": 패키지란? 패키지 엔트리 포인트(entry point) 패키지 관리 시스템 패키지 생성 모듈의 정의 Python에서 모듈은 일반적으로 함수, 클래스, 변수로 구성된 Python 코드를 포함하는 파일로, 다른 Python 스크립트에서 가져와서 사용할 수 있습니다. 모듈은 코드를 더 작은 독립된 조각으로 나누어 정리하고 재사용하는 방법입니다. 모듈을 사용하면 코드를 복제하지 않고도 여러 스크립트나 프로젝트에서 기능을 공유할 수 있으므로 유지 관리와 업데이트가 더 쉬워집니다. 모듈의 주요 목적은 코드 재사용성, 모듈성 및 유지보수성을 가능하게 하는 것입니다. 모듈을 가져오면 해당 모듈의 모든 함수, 클래스,..
2023.05.06
[Python] 2. 외부 모듈 세부 사항
목차 외부 모듈 설치 방법과 예시 외부 모듈 설치 Beautiful Soup Flask Django Django와 Flask 외부 모듈 세부 사항 라이브러리 프레임워크 제어 역전 함수 데코레이터 라이브러리 라이브러리는 프로젝트에서 가져오고 사용할 수 있는 미리 작성된 코드, 함수, 클래스 및 기타 리소스의 모음입니다. 라이브러리는 개발자에게 재사용 가능한 코드를 제공하여 일반적인 작업과 기능을 위해 바퀴를 재발명하지 않아도 되므로 시간과 노력을 절약할 수 있습니다. 라이브러리는 두 가지 주요 유형으로 분류할 수 있습니다. 표준 라이브러리 기본적으로 프로그래밍 언어와 함께 제공되는 라이브러리입니다. 예를 들어 Python의 표준 라이브러리에는 파일 처리(os, shutil), 정규식(re), 수학 함수(m..
2023.05.06
[Python] 1. 외부 모듈 설치 방법과 예시
목차 외부 모듈 설치 방법과 예시 외부 모듈 설치 Beautiful Soup Flask Django Django와 Flask 외부 모듈 세부 사항 라이브러리 프레임워크 제어 역전 함수 데코레이터 외부 모듈 설치 파이썬에서 외부 모듈을 설치하려면 일반적으로 파이썬 패키지 설치 관리자(pip)를 사용합니다. pip를 사용하여 외부 모듈을 설치하는 방법은 다음과 같습니다. 1. 명령 프롬프트(Windows) 또는 터미널(macOS 및 Linux)을 엽니다. 2. 다음 명령어를 입력하고 Enter 키를 누릅니다. pip install module_name 3. "module_name"을 설치하려는 외부 모듈의 이름으로 바꿉니다. 예를 들어, 인기있는 "requests" 모듈을 설치하려면 명령은 다음과 같습니다...
2023.05.06
[일간 이슈] 5월 6일 (토) IT 관련 뉴스 모음(+요약)
뉴스를 빠르게 찾기 위해 Ctrl +F 를 눌러 들어오신 키워드를 검색해보세요! 목차 [팩플] 오픈AI “130조 투자 유치하겠다”... 생성AI ‘돈 싸움’ 시작되나 애플 1분기 실적 선방…"아이폰이 다 했다" 실적반등 노리는 삼성…'갤Z 조기출시' 승부수 AI發 가짜 정보 확산…"나 빼고 모두 AI?" "챗GPT가 패션 코디 추천해요"…옴니어스, 'AI 스타일챗' 개발 KAIST AI 기술, 국제학회 최우수상 美 이번엔 '기술표준 연합군'… 中 더 옥죈다 "中, 대만 침공땐 세계경제 연1조弗 피해" [매경춘추] ChatGPT, 이제 서비스다 [클라우드+] 신한은행 배달앱 '땡겨요' 성공 비결은 ◯◯◯◯ 알리바바 클라우드, 아발란체와 메타버스 플랫폼도 협력 NHN클라우드, AI EXPO KOREA 20..
2023.05.06
[프로젝트] 파이썬 미니 프로젝트 Day.5
오늘은 MySQL을 다운로드 받고 이전에 제작한 html과 DB를 연결해 로그인 기능을 구현하려 했습니다. 해당 내용을 구현하기 위해 해당 페이지를 참고했으나 제작하는 과정에서 오류가 많이 나와 오늘은 미완성인 채로 아쉽게 마무리 되었습니다. 이전에 중구난방으로 html과 css를 제작했었으나 이번에는 각각 폴더를 지정해 몰아 넣어 정리했습니다. 하지만, 저는 오늘 건강관계상 같이 토론은 못하고 내용을 전달받고 이 코드가 무슨뜻인지 주석을 달아주는 것 밖에 못했습니다. DB랑 연결해서 실험을 해봐야하는데, 오늘은 이렇게 가볍게 마치고 이번 주말에 더 공부해볼 생각입니다. 다음은 코드와 무슨 뜻인지 정리되어있으니 참고할 수 있을 것으로 생각됩니다. 참고로 html의 주석은 , 파이썬의 주석은 #, sql의..
2023.05.05
반응형

목차

  • 모듈이란?
    1. 모듈의 정의
    2. 모둘 생성
    3. __name__
    4. if __name__ == "__main__":
  • 패키지란?
    1. 엔트리 포인트(entry point)
    2. 패키지
    3. 패키지 관리 시스템
    4. 패키지 생성

엔트리 포인트(entry point)

엔트리 포인트(entry point)는 프로그램이 실행될 때 실행되는 첫 번째 코드 줄입니다. main 함수 또는 'main'은 종종 많은 프로그래밍 언어에서 엔트리 포인트(entry point) 역할을 합니다. 그러나 Python에는 C, C++ 또는 Java와 같은 다른 프로그래밍 언어와 같은 기본 제공 main 기능이 없습니다.

대신 Python은 특수 변수 __name__을 사용하여 스크립트가 기본 프로그램으로 실행되고 있는지 또는 다른 스크립트에 모듈로 가져오고 있는지를 결정합니다. Python 스크립트가 실행될 때 스크립트가 기본 프로그램으로 실행되는 경우 인터프리터는 __name__ 변수를 "__main__"으로 설정합니다. 이 경우 스크립트의 엔트리 포인트(entry point)는 if __name__ == "__main__": 블록 다음 코드의 첫 번째 줄입니다.

Python 스크립트의 일반적인 패턴은 프로그램의 기본 논리를 포함하는 main() 함수를 정의한 다음 if __name__ == "__main__": 블록을 사용하여 스크립트가 실행될 때 해당 함수를 호출하는 것입니다. 메인 프로그램으로. 예를 들면 다음과 같습니다.

def main():
    print("This is the main function of the script.")

def another_function():
    print("This is another function.")

if __name__ == "__main__":
    main()


이 예제에서 main() 함수는 메인 프로그램으로 실행될 때 스크립트의 엔트리 포인트(entry point) 역할을 합니다. 스크립트를 모듈로 가져오면 main() 함수가 자동으로 실행되지 않지만 필요한 경우 명시적으로 호출할 수 있습니다.

이러한 방식으로 코드를 구성하면 모듈로 가져올 때 실행되는 코드와 프로그램의 기본 논리를 분리하여 스크립트를 더 모듈화하고 이해하기 쉽게 만들 수 있습니다.


패키지

패키지(package)는 파이썬의 모듈을 구조화하고 조직화하는 데 사용되는 방법입니다. 패키지는 여러 모듈을 하나의 디렉토리에 그룹화하여 관리할 수 있게 합니다. 이를 통해 복잡한 프로젝트를 더 간결하게 관리하고, 다른 프로젝트에서 패키지를 재사용하기 쉽게 만듭니다.

패키지를 생성하는 방법은 다음과 같습니다.

1. 패키지 디렉토리 생성
먼저 패키지를 포함할 디렉토리를 생성합니다. 예를 들어, my_package라는 이름의 디렉토리를 생성할 수 있습니다.

2. __init__.py 파일 생성
패키지 디렉토리에 __init__.py 파일을 생성합니다. 이 파일은 패키지가 로드될 때 초기화 코드를 실행할 수 있도록 합니다. 또한 이 파일이 있어야 파이썬이 해당 디렉토리를 패키지로 인식합니다. 이 파일은 비워 둘 수도 있습니다.

3. 패키지에 모듈 추가
패키지 디렉토리에 모듈 파일(.py 파일)을 추가합니다. 예를 들어, my_package 디렉토리에 module1.py, module2.py와 같은 모듈을 추가할 수 있습니다.

4. 패키지 구조 예시

my_package/
    __init__.py
    module1.py
    module2.py


5. 패키지를 사용하는 방법

# 다른 파이썬 코드에서 패키지 사용
import my_package.module1
import my_package.module2

# 또는
from my_package import module1, module2

# 모듈 내 함수 사용 예시
result = my_package.module1.some_function()


패키지를 사용하면 여러 모듈을 하나의 디렉토리로 묶어 관리할 수 있으며, 관련된 기능을 한 곳에서 관리할 수 있어 프로젝트 구조를 더욱 체계적으로 만들 수 있습니다.


패키지 관리 시스템

Python은 pip(Pip Installs Packages)라는 패키지 관리 시스템을 사용하여 타사 패키지 또는 라이브러리를 설치하고 관리합니다. pip는 Python의 기본 패키지 관리자이며 Python 3.4부터 Python 설치와 함께 번들로 제공됩니다.

pip를 사용하면 무엇보다도 패키지를 검색하고 패키지를 설치, 제거 및 업데이트할 수 있습니다. Python Package Index(PyPI)를 기본 리포지토리로 사용하여 패키지를 찾고 다운로드합니다. PyPI는 커뮤니티에서 기여한 방대한 Python 패키지 모음이며 대부분의 Python 패키지에 대한 중앙 리포지토리 역할을 합니다.

다음은 pip와 함께 사용할 수 있는 몇 가지 기본 명령입니다.

1. 패키지 설치

pip install package_name


2. 패키지 제거

pip uninstall package_name


3. 패키지 업그레이드

pip install --upgrade package_name


4. 설치된 패키지 나열

pip list


5. 패키지 검색

pip search package_name


6. 패키지 정보 표시

pip show package_name


pip를 사용하려면 시스템에 Python이 설치되어 있어야 하며 명령 프롬프트, 터미널 또는 셸에서 pip를 사용할 수 있어야 합니다. 시스템 전체에 패키지를 설치하려면 관리자 또는 루트 권한이 필요할 수 있습니다. 또는 가상 환경을 사용하여 시스템 Python 설치에 영향을 주지 않고 특정 프로젝트에 대한 패키지를 설치할 수 있습니다.


패키지 생성

Python 패키지를 만드는 것은 코드를 정리하고 공유할 수 있는 좋은 방법입니다. 다음은 간단한 패키지를 만드는 단계별 가이드입니다.

1. 패키지 이름을 선택하고 디렉토리 구조를 만듭니다.
패키지를 설명할 수 있는 고유한 이름을 선택합니다. 이 예에서는 my_package를 사용하겠습니다. 같은 이름의 디렉터리를 만든 다음 그 안에 my_package라는 하위 디렉터리를 만듭니다.

my_package/
    my_package/


2. __init__.py 파일을 추가합니다.
__init__.py 파일은 디렉터리를 파이썬 패키지로 표시하여 인터프리터가 이를 모듈로 취급할 수 있도록 하는 데 사용됩니다. my_package 하위 디렉토리에 빈 __init__.py 파일을 추가합니다.

my_package/
    my_package/
        __init__.py


3. 코드를 추가합니다.
이제 Python 코드 파일(모듈)을 my_package 하위 디렉터리에 추가합니다. 이 예제에서는 say_hello 함수가 있는 간단한 hello.py 모듈을 추가하겠습니다.


hello.py:

def say_hello(name):
    print(f"안녕하세요, {이름}!")


이제 패키지 구조가 다음과 같이 보일 것입니다.

my_package/
    my_package/
        __init__.py
        hello.py


4. (선택 사항) README.md 파일을 추가합니다.
패키지 루트 디렉터리에 README.md 파일을 포함하는 것이 좋습니다. 이 파일에는 패키지에 대한 설명, 목적, 사용 방법이 포함되어야 합니다.

5. (선택 사항) LICENSE 파일을 추가합니다.
패키지 루트 디렉터리에 LICENSE 파일을 포함시켜 코드를 사용, 수정 및 배포할 수 있는 조건을 지정해야합니다.

6. (선택 사항) setup.py 파일을 추가합니다.
패키지를 배포하려는 경우(예: PyPI에 업로드) 패키지 루트 디렉터리에 setup.py 파일을 생성해야합니다. 이 파일은 패키지에 대한 메타데이터와 설치 지침을 제공합니다.

기본 setup.py 파일은 다음과 같습니다.

from setuptools import setup, find_packages

setup(
    name="my_package",
    version="0.1.0",
    packages=find_packages(),
    install_requires=[],
)


이 과정을 통해 간단한 Python 패키지를 만들었습니다. 이제 패키지 루트 디렉터리를 PYTHONPATH에 추가하거나 pip로 설치하여 다른 Python 프로젝트에서 이 패키지를 사용할 수 있습니다. 배포 가능한 패키지를 만들려면 setuptools를 사용하여 소스 배포 또는 휠 배포를 생성한 다음 다른 사람이 pip를 사용하여 설치할 수 있습니다. 이렇게 하려면 터미널에서 다음 명령을 실행합니다.

# 설치도구 및 휠 설치(아직 설치되지 않은 경우)
pip install setuptools wheel

# 패키지 배포를 생성합니다(.tar.gz 및 .whl 파일 생성).
python setup.py sdist bdist_wheel


이제 프로젝트에서 사용하거나 다른 사람들과 공유하거나 PyPI와 같은 패키지 리포지토리를 통해 배포할 수 있는 Python 패키지가 생겼습니다. 패키지를 더욱 유용하고 유지 관리하기 쉽게 만들려면 깔끔하고 잘 문서화되고 테스트된 코드를 작성하기 위한 모범 사례를 따르는 것을 잊지 말아야합니다.

반응형
반응형

목차

  • 모듈이란?
    1. 모듈의 정의
    2. 모둘 생성
    3. __name__
    4. if __name__ == "__main__":
  • 패키지란?
    1. 패키지
    2. 엔트리 포인트(entry point)
    3. 패키지 관리 시스템
    4. 패키지 생성

모듈의 정의

Python에서 모듈은 일반적으로 함수, 클래스, 변수로 구성된 Python 코드를 포함하는 파일로, 다른 Python 스크립트에서 가져와서 사용할 수 있습니다. 모듈은 코드를 더 작은 독립된 조각으로 나누어 정리하고 재사용하는 방법입니다. 모듈을 사용하면 코드를 복제하지 않고도 여러 스크립트나 프로젝트에서 기능을 공유할 수 있으므로 유지 관리와 업데이트가 더 쉬워집니다.

모듈의 주요 목적은 코드 재사용성, 모듈성 및 유지보수성을 가능하게 하는 것입니다. 모듈을 가져오면 해당 모듈의 모든 함수, 클래스, 변수에 액세스할 수 있으므로 자체 스크립트에서 사용할 수 있습니다.

모듈은 파일명으로 식별되며 Python 모듈의 파일 확장자는 .py입니다. 스크립트에서 모듈을 사용하려면 파일 확장자 없이 모듈 이름 뒤에 import 문을 사용해야 합니다. 예를 들어 example_module.py라는 이름의 모듈이 있는 경우 다음과 같이 스크립트로 가져올 수 있습니다:

import example_module


모듈을 가져온 후에는 모듈 이름 앞에 점 하나를 붙여서 모듈의 함수, 클래스, 변수를 사용할 수 있습니다. 예를 들어

result = example_module.some_function()


모듈에서 특정 함수나 클래스를 가져오려면 from 키워드를 사용하거나, 편의를 위해 모듈이나 그 멤버에 별칭을 지정하려면 as 키워드를 사용할 수도 있습니다.


모둘 생성

Python에서 모듈은 간단하게 만들 수 있습니다. 모듈은 기본적으로 파이썬 코드가 저장된 .py 파일입니다. 이 파일에 함수, 클래스, 변수 등을 정의하면 다른 파이썬 코드에서 이 모듈을 사용할 수 있습니다. 다음은 모듈을 만드는 방법과 예시입니다.

1. 모듈 파일 생성
먼저 새로운 .py 파일을 만들어 봅시다. 예를 들어, mymodule.py라는 이름으로 파일을 생성할 수 있습니다.

2. 모듈에 코드 추가
mymodule.py 파일에 함수, 클래스, 변수 등을 정의합니다.

예시:

# mymodule.py

def add(a, b):
    return a + b

def subtract(a, b):
    return a - b

pi = 3.141592


위의 예시에서는 두 개의 함수(add, subtract)와 하나의 변수(pi)를 정의했습니다.

3. 다른 파이썬 코드에서 모듈 사용
이제 다른 파이썬 코드에서 mymodule.py를 사용할 수 있습니다. import 문을 사용하여 모듈을 불러올 수 있습니다.
예시:

# main.py

import mymodule

result1 = mymodule.add(1, 2)
print(result1)  # 출력: 3

result2 = mymodule.subtract(5, 3)
print(result2)  # 출력: 2

print(mymodule.pi)  # 출력: 3.141592


위의 예시에서는 main.py 파일에서 mymodule을 import하여 정의된 함수와 변수를 사용했습니다.

모듈을 만들고 사용하는 방법은 이처럼 간단하며, 코드를 재사용하고 조직화하는 데 도움이 됩니다. 다양한 기능을 모듈별로 분리하여 관리하면 유지 보수성도 향상됩니다.


__name__

Python에서 특수 변수 __name__은 Python 스크립트가 기본 프로그램으로 실행되는지 또는 다른 스크립트에 모듈로 가져오는지 결정하는 데 사용됩니다. Python 스크립트가 실행될 때 스크립트가 기본 프로그램으로 실행되는 경우 인터프리터는 __name__ 변수를 "__main__"으로 설정합니다. 스크립트를 다른 스크립트에 모듈로 가져오는 경우 __name__ 변수는 스크립트 이름으로 설정됩니다(.py 확장자 없음).

이는 스크립트가 모듈로 가져올 때가 아니라 기본 프로그램으로 실행될 때만 실행되어야 하는 일부 코드를 스크립트에 포함하려는 경우에 유용합니다. 예를 들면 다음과 같습니다.

def my_function():
    print("This is my function.")

if __name__ == "__main__":
    print("This script is being run as the main program.")
    my_function()
else:
    print("This script is being imported as a module.")


이 예에서 if __name__ == "__main__": 블록 내부의 print 문과 my_function()에 대한 호출은 스크립트가 기본 프로그램으로 실행될 때만 실행됩니다. 스크립트를 모듈로 가져오면 print 문과 함수 호출을 건너뛰고 else 블록만 실행합니다.


if __name__ == "__main__"

if __name__ == "__main__":은 스크립트가 기본 프로그램으로 실행되는지 또는 다른 스크립트에 모듈로 가져오는지 결정하는 데 사용되는 일반적인 Python 관용구입니다. 이렇게 하면 스크립트를 모듈로 가져올 때 실행되는 코드에서 프로그램의 기본 논리를 분리할 수 있습니다.

Python 스크립트가 실행될 때 스크립트가 기본 프로그램으로 실행되는 경우 인터프리터는 __name__ 변수를 "__main__"으로 설정합니다. 스크립트를 다른 스크립트에 모듈로 가져오는 경우 __name__은 스크립트 이름(파일 확장자 없음)으로 설정됩니다.

if __name__ == "__main__":을 사용하는 방법은 다음과 같습니다.

1. main() 함수 또는 프로그램의 기본 논리를 캡슐화하는 유사한 함수를 정의합니다.

def main():
    print("This is the main function of the script.")


2. 스크립트의 일부인 다른 함수나 클래스를 작성합니다.

def another_function():
    print("This is another function.")


3. 스크립트 끝에 if __name__ == "__main__": 블록을 추가하고 main() 함수 또는 1단계에서 정의한 함수를 호출합니다.

if __name__ == "__main__":
    main()


스크립트를 메인 프로그램으로 실행하면 main() 함수가 실행되고 "This is the main function of the script"라는 출력이 표시됩니다. 스크립트를 모듈로 다른 스크립트로 가져오면 main() 함수가 자동으로 실행되지 않지만 필요한 경우 여전히 명시적으로 호출할 수 있습니다.

if __name__ == "__main__":을 사용하면 스크립트의 기본 논리가 기본 프로그램으로 실행될 때만 실행되도록 할 수 있습니다. 이렇게 하면 코드를 보다 효과적으로 구성하고 모듈식으로 만들 수 있습니다. 이해하기 쉽습니다.


반응형
반응형

목차

  • 외부 모듈 설치 방법과 예시
    1. 외부 모듈 설치
    2. Beautiful Soup
    3. Flask
    4. Django
    5. Django와 Flask
  • 외부 모듈 세부 사항
    1. 라이브러리
    2. 프레임워크
    3. 제어 역전
    4. 함수 데코레이터

라이브러리

라이브러리는 프로젝트에서 가져오고 사용할 수 있는 미리 작성된 코드, 함수, 클래스 및 기타 리소스의 모음입니다. 라이브러리는 개발자에게 재사용 가능한 코드를 제공하여 일반적인 작업과 기능을 위해 바퀴를 재발명하지 않아도 되므로 시간과 노력을 절약할 수 있습니다.

라이브러리는 두 가지 주요 유형으로 분류할 수 있습니다.

  • 표준 라이브러리
    기본적으로 프로그래밍 언어와 함께 제공되는 라이브러리입니다. 예를 들어 Python의 표준 라이브러리에는 파일 처리(os, shutil), 정규식(re), 수학 함수(math) 등을 위한 모듈이 포함되어 있습니다. 이러한 라이브러리는 프로그래밍 언어를 설치할 때 즉시 사용할 수 있으므로 별도로 설치할 필요가 없습니다.

  • 외부 라이브러리
    타사에서 개발한 라이브러리이며 기본적으로 프로그래밍 언어에 포함되어 있지 않습니다. 개발자는 일반적으로 Python용 pip, JavaScript용 npm 또는 Ruby용 gem과 같은 패키지 관리자를 사용하여 외부 라이브러리를 별도로 설치해야 합니다. 외부 라이브러리의 예로는 수치 컴퓨팅을 위한 NumPy, 웹 개발을 위한 Flask, Python의 기계 학습을 위한 TensorFlow가 있습니다.

코드에서 라이브러리를 사용하려면 일반적으로 import 문을 사용하여 라이브러리를 가져와야 합니다. 예를 들어 파이썬에서는 다음과 같습니다.

import os

 

이렇게 하면 Python의 표준 라이브러리에서 os 모듈을 가져와 함수와 클래스에 액세스할 수 있습니다.

라이브러리는 개발자에게 사전 구축된 솔루션과 모범 사례를 제공하여 효율적이고 유지 관리 가능하며 확장 가능한 코드를 쉽게 작성할 수 있도록 함으로써 소프트웨어 개발에서 중요한 역할을 합니다. 또한 개발자가 기존 라이브러리를 기반으로 새로운 기능을 생성할 수 있으므로 코드 재사용성과 모듈성을 촉진합니다.


프레임워크

프레임워크(framework)는 소프트웨어 개발에 필요한 기본 구조와 코드를 제공하는 템플릿입니다. 프레임워크는 개발자가 일반적인 프로그래밍 문제를 효과적으로 해결하고, 빠르게 신뢰할 수 있는 소프트웨어를 개발하는 데 도움이 됩니다.

프레임워크의 주요 목적은 다음과 같습니다.

  • 코드 재사용성
    프레임워크는 공통적인 기능 및 구조를 제공함으로써 개발자들이 중복 코드를 최소화하고 공통 작업을 재사용할 수 있게 돕습니다.

  • 개발 속도 향상
    프레임워크를 사용하면 개발자가 효과적인 구조와 기본 기능을 갖춘 애플리케이션을 빠르게 구축할 수 있습니다.

  • 유지 관리와 확장성
    프레임워크는 일관된 구조와 디자인 패턴을 제공하여 소프트웨어를 쉽게 유지 관리하고 확장할 수 있는 기반을 제공합니다.

프레임워크는 다양한 프로그래밍 언어와 사용 사례에 적용할 수 있습니다. 웹 개발, 모바일 애플리케이션, 데이터베이스 관리, 기계 학습 등 다양한 분야에서 프레임워크가 활용되고 있습니다.

프레임워크의 예시는 다음과 같습니다.

  • 웹 개발
    • Python: Django, Flask
    • JavaScript: Angular, React, Vue.js
    • Ruby: Ruby on Rails
    • PHP: Laravel, Symfony
  • 모바일 애플리케이션 개발
    • iOS: Swift, Objective-C
    • Android: Java, Kotlin
  • 기계 학습 및 데이터 분석
    • Python: TensorFlow, PyTorch, Scikit-learn, Pandas

프레임워크를 사용하면 개발자는 표준화된 방식으로 문제를 해결할 수 있으며, 쉽게 이해할 수 있는 코드와 효율적인 개발 프로세스를 구현할 수 있습니다. 프레임워크는 개발자가 새로운 기능 및 기술을 쉽게 통합하고, 소프트웨어의 안정성 및 성능을 높일 수 있도록 지원합니다.


제어 역전

제어 역전(Inversion of Control, IoC)은 소프트웨어 개발에서 객체 지향 디자인 원칙 중 하나로, 컴포넌트 간의 제어 흐름과 종속성을 역전시키는 것을 의미합니다. 일반적으로, 프로그램의 제어 흐름은 메인 함수나 전역 프로시저가 결정합니다. 제어 역전은 이러한 메인 함수나 전역 프로시저의 역할을 프레임워크나 라이브러리로 이동시켜, 프레임워크가 개발자가 작성한 컴포넌트의 실행 순서와 타이밍을 결정합니다.

제어 역전의 주요 목적은 다음과 같습니다.

  • 모듈 간의 결합도를 낮추기
    제어 역전을 사용하면 의존성이 라이브러리나 프레임워크에 위임되므로, 개별 모듈 간의 결합도를 낮출 수 있습니다.

  • 코드의 재사용성 향상
    제어 역전을 사용하면 공통 기능을 분리하고 중앙에서 관리할 수 있어, 코드 재사용성이 향상됩니다.

  • 유지 보수성 개선
    모듈 간 결합도가 낮아지면 유지 보수성이 향상되며, 개발자는 개별 모듈에 집중할 수 있습니다.

제어 역전은 종종 의존성 주입(Dependency Injection, DI)과 혼동되곤 합니다. 의존성 주입은 제어 역전을 구현하는 한 가지 방법으로, 컴포넌트 간의 의존성을 외부에서 주입해주는 기술입니다. 의존성 주입을 통해 개별 컴포넌트가 직접 의존성을 생성하거나 찾는 대신 외부에서 의존성을 주입받으므로, 결합도를 낮추고 유연성과 테스트 용이성을 높일 수 있습니다. 


함수 데코레이터

함수 데코레이터는 Python의 고급 기능 중 하나로, 함수의 기능을 수정하거나 확장할 때 사용됩니다. 데코레이터는 다른 함수를 인자로 받는 callable 객체(일반적으로 함수)입니다. 이 callable 객체는 원래 함수를 감싸고 추가 기능을 제공하거나 기존 기능을 수정하는 역할을 합니다.

데코레이터는 다음과 같은 구문으로 사용됩니다.

@decorator
def function_to_decorate():
    pass


이 구문은 다음 코드와 동일한 작업을 수행합니다:

function_to_decorate = decorator(function_to_decorate)


데코레이터를 사용하는 이유는 다양하며, 일반적으로 다음과 같은 경우에 사용됩니다.

  • 코드 재사용: 데코레이터를 사용하면 공통 기능을 여러 함수에서 쉽게 재사용할 수 있습니다.
  • 코드 분리: 데코레이터를 사용하면 함수의 주요 기능과 추가 기능을 분리하여 코드를 더 쉽게 이해하고 유지 관리할 수 있습니다.
  • 기능 추가: 기존 함수를 수정하지 않고도 새로운 기능을 추가할 수 있습니다.

데코레이터 예시

def simple_decorator(func):
    def wrapper():
        print("Something is happening before the function is called.")
        func()
        print("Something is happening after the function is called.")
    return wrapper

@simple_decorator
def say_hello():
    print("Hello!")

say_hello()


이 코드의 출력 결과는 다음과 같습니다:

Something is happening before the function is called.
Hello!
Something is happening after the function is called.


이 예시에서 simple_decorator는 데코레이터 함수이며, say_hello 함수를 인자로 받아 wrapper 함수를 반환합니다. wrapper 함수는 원래 함수인 say_hello가 호출되기 전후에 추가적인 작업을 수행합니다. 데코레이터를 사용하면 기존 함수의 기능을 수정하거나 확장할 수 있으며, 코드 재사용성과 유지 관리성을 높일 수 있습니다.


 

반응형
반응형

목차

  • 외부 모듈 설치 방법과 예시
    1. 외부 모듈 설치
    2. Beautiful Soup
    3. Flask
    4. Django
    5. Django와 Flask
  • 외부 모듈 세부 사항
    1. 라이브러리
    2. 프레임워크
    3. 제어 역전
    4. 함수 데코레이터

외부 모듈 설치

파이썬에서 외부 모듈을 설치하려면 일반적으로 파이썬 패키지 설치 관리자(pip)를 사용합니다. pip를 사용하여 외부 모듈을 설치하는 방법은 다음과 같습니다.

1. 명령 프롬프트(Windows) 또는 터미널(macOS 및 Linux)을 엽니다.


2. 다음 명령어를 입력하고 Enter 키를 누릅니다.

pip install module_name


3. "module_name"을 설치하려는 외부 모듈의 이름으로 바꿉니다. 예를 들어, 인기있는 "requests" 모듈을 설치하려면 명령은 다음과 같습니다.

pip install requests


4. 설치 과정이 완료될 때까지 기다립니다. 모듈이 설치되면 파이썬 스크립트에서 가져와서 사용할 수 있습니다.


Beautiful Soup

Beautiful Soup은 HTML 및 XML 문서에서 데이터를 추출하기 위해 웹 스크래핑 목적으로 사용되는 Python 라이브러리입니다. HTML 및 XML 파일에서 구문 분석 트리를 생성하여 데이터를 쉽게 추출하는 데 사용할 수 있습니다. Beautiful Soup은 구문 분석 트리를 탐색, 검색 및 수정하기 위한 몇 가지 간단한 메서드와 Python 관용구를 제공합니다.

Beautiful Soup을 사용하려면 먼저 설치해야 합니다.

pip install beautifulsoup4


Beautiful Soup을 설치한 후 라이브러리를 가져오고 HTML 콘텐츠를 가져오기 위해 requests와 같은 HTTP 라이브러리와 결합하여 Python 스크립트에서 사용할 수 있습니다.

import requests
from bs4 import BeautifulSoup

url = "https://example.com"
response = requests.get(url)

soup = BeautifulSoup(response.text, "html.parser")


이제 BeautifulSoup 개체를 만들었으므로 라이브러리에서 제공하는 다양한 메서드를 사용하여 HTML 콘텐츠에서 특정 요소에 액세스하고 추출할 수 있습니다. 몇 가지 일반적인 방법은 다음과 같습니다.

  • find(): 주어진 속성과 일치하는 태그의 첫 번째 항목을 검색합니다.
  • find_all(): 주어진 속성과 일치하는 태그의 모든 항목을 검색합니다.
  • select(): 주어진 CSS 선택자와 일치하는 태그를 검색합니다.
  • get_text(): 태그에서 텍스트 콘텐츠를 추출합니다.

다음은 웹페이지에서 모든 링크를 추출하는 간단한 예입니다.

import requests
from bs4 import BeautifulSoup

url = "https://example.com"
response = requests.get(url)

soup = BeautifulSoup(response.text, "html.parser")

# Find all 'a' tags
links = soup.find_all('a')

# Extract and print the 'href' attribute of each link
for link in links:
    print(link.get('href'))


Beautiful Soup은 사용하기 쉽고 잘못된 마크업을 우아하게 처리할 수 있기 때문에 웹 스크래핑 작업에 널리 사용됩니다.


Flask

Flask는 웹 애플리케이션을 쉽게 만들 수 있는 가볍고 유연한 Python 웹 프레임워크입니다. Flask는 도구, 라이브러리 및 간단한 API를 제공하여 최소한의 설정 및 상용구 코드로 웹 애플리케이션을 만드는 데 도움을 줍니다. 마이크로 프레임워크로 간주되며, 이는 작고 집중적이며 외부 라이브러리 및 플러그인으로 쉽게 확장할 수 있음을 의미합니다.

1. Flask의 일부 주요 기능은 다음과 같습니다.

  • 라우팅
    Flask를 사용하면 들어오는 요청을 처리하고 응답을 생성하는 Python 함수에 URL을 매핑하여 웹 애플리케이션에 대한 경로를 간단하게 정의할 수 있습니다.

  • 템플릿
    Flask는 간단한 템플릿 구문을 사용하여 동적 HTML 페이지를 생성할 수 있는 Jinja2 템플릿 엔진을 사용합니다.

  • 양식 및 입력 처리
    Flask는 제출된 데이터의 유효성 검사 및 처리를 포함하여 웹 양식에서 사용자 입력을 처리하기 위한 기본 제공 지원을 제공합니다.

  • 세션 및 쿠키
    Flask를 사용하면 세션 변수 및 쿠키를 사용하여 사용자별 데이터를 저장하고 관리할 수 있습니다.

  • 확장 및 플러그인
    Flask에는 데이터베이스 통합, 사용자 인증 등과 같은 기능을 웹 애플리케이션에 추가하는 데 사용할 수 있는 확장 및 플러그인의 풍부한 생태계가 있습니다.

2. Flask를 시작하려면 먼저 Flask를 설치해야 합니다.

pip install Flask


3. 설치 후 위의 예제 코드로 새 Python 파일을 만들고 실행하여 Flask 웹 애플리케이션을 시작할 수 있습니다. 다음은 Flask 웹 애플리케이션의 간단한 예입니다.

from flask import Flask

app = Flask(__name__)

@app.route('/')
def hello():
    return 'Hello, World!'

if __name__ == '__main__':
    app.run(debug=True)


이 코드는 루트 URL("/")에 매핑되는 단일 경로가 있는 기본 Flask 웹 애플리케이션을 만듭니다. 사용자가 이 URL을 방문하면 hello 함수가 호출되어 "Hello, World!" 메시지. app.run(debug=True) 라인은 디버그 모드가 활성화된 상태로 개발 서버를 시작하여 문제가 발생할 경우 자세한 오류 메시지를 볼 수 있습니다.


Django

Django는 빠른 개발과 깨끗하고 실용적인 디자인을 장려하는 높은 수준의 오픈 소스 Python 웹 프레임워크입니다. MVT(Model-View-Template) 아키텍처 패턴을 따르며 개발자가 확장 가능하고 유지 관리 가능한 웹 애플리케이션을 구축하는 데 도움을 주는 것을 목표로 합니다. Django는 강력하고 내장된 기능으로 유명하므로 복잡한 데이터 기반 웹 애플리케이션을 만드는 데 탁월한 선택입니다.

1. Django의 몇 가지 주요 기능은 다음과 같습니다.

  • 관리 인터페이스
    Django는 애플리케이션 데이터 관리를 위한 기본 제공 관리 인터페이스를 제공하므로 모델에서 CRUD(만들기, 읽기, 업데이트, 삭제) 작업을 쉽게 수행할 수 있습니다.

  • URL 라우팅
    Django를 사용하면 웹 애플리케이션의 URL 패턴을 정의하고 해당 보기에 매핑할 수 있습니다.

  • ORM(Object-Relational Mapping)
    Django의 ORM을 사용하면 원시 SQL 쿼리를 작성하는 대신 Python 클래스 및 객체를 사용하여 데이터베이스와 상호 작용할 수 있습니다. PostgreSQL, MySQL, SQLite 및 Oracle을 포함한 다양한 데이터베이스 시스템을 지원합니다.

  • 양식 및 입력 처리
    Django는 사용자 입력, 유효성 검사 및 HTML 양식 렌더링을 단순화하는 강력한 양식 시스템을 제공합니다.

  • 템플릿
    Django는 자체 템플릿 엔진을 사용하여 동적 HTML 페이지를 생성합니다. 템플릿 구문은 배우기 쉽고 유연하여 재사용 가능한 템플릿과 구성 요소를 만들 수 있습니다.

  • 인증 및 권한 부여
    Django에는 사용자 인증 및 권한 부여 지원 기능이 내장되어 있어 애플리케이션에서 사용자 계정, 권한 및 액세스 제어를 쉽게 관리할 수 있습니다.

  • 미들웨어
    Django의 미들웨어 시스템을 사용하면 요청과 응답이 보기에 도달하기 전이나 보기를 떠난 후에 전역적으로 처리할 수 있으므로 보안, 세션 관리 및 캐싱과 같은 측면을 처리할 수 있습니다.

  • 확장성
    Django에는 타사 앱과 플러그인의 풍부한 생태계가 있어 애플리케이션의 기능을 쉽게 확장할 수 있습니다.

2. Django를 시작하려면 먼저 Django를 설치해야 합니다.

pip install Django

 

일단 설치되면 Django의 명령줄 도구를 사용하여 새 프로젝트를 만들고 웹 애플리케이션 구축을 시작할 수 있습니다.


Django와 Flask

Django와 Flask는 둘 다 널리 사용되는 Python 웹 프레임워크이지만 서로 다른 디자인 철학을 가지고 있으며 서로 다른 요구 사항을 충족합니다. 기능을 비교하면 다음과 같습니다.

1. 디자인 철학
Django는 "batteries-included" 접근 방식을 따르며 일반적인 작업을 위한 내장 기능 및 도구가 포함된 전체 스택 솔루션을 제공합니다. MVT(Model-View-Template) 아키텍처 패턴을 준수합니다.

반면 Flask는 단순성과 유연성을 강조하는 마이크로 프레임워크입니다. 구성 요소를 선택하고 원하는 방식으로 애플리케이션을 빌드할 수 있습니다. Flask는 WSGI(Web Server Gateway Interface) 표준을 따릅니다.

2. 학습 곡선
Django는 광범위한 기능과 구성 요소로 인해 초보자가 배우기에 더 어려울 수 있습니다. 그러나 규칙에 익숙해지면 개발 프로세스 속도를 높일 수 있습니다.

Flask는 최소한의 접근 방식을 사용하고 따라야 할 규칙이 적기 때문에 특히 웹 개발을 처음 접하는 사람들이 배우기 쉽습니다.

3. 유연성
Django는 독단적이며 응용 프로그램을 구성하고 구축하는 특정 방법을 권장합니다. 이것은 일관성을 유지하고 모범 사례를 따르는 데 도움이 될 수 있지만 일부 개발자에게는 제한적으로 느껴질 수 있습니다.

Flask는 구성 요소를 선택하고 응용 프로그램을 구성하는 데 더 많은 자유를 제공합니다. 이러한 유연성은 처음부터 응용 프로그램을 구축하는 것을 선호하는 숙련된 개발자에게 매력적일 수 있습니다.

4. 내장 기능
Django는 관리 인터페이스, ORM, 인증 및 양식 처리와 같은 강력한 내장 기능 세트와 함께 제공됩니다.

마이크로 프레임워크인 Flask는 기본 제공 기능이 적습니다. 그러나 타사 확장 및 라이브러리를 사용하여 기능을 확장할 수 있습니다.

5. 확장성
Django와 Flask 모두 확장 가능한 애플리케이션을 구축하는 데 사용할 수 있지만 접근 방식이 다릅니다. Django의 내장 기

능을 사용하면 복잡한 기능을 가진 대규모 애플리케이션을 더 쉽게 구축할 수 있습니다.

Flask의 모듈 방식을 사용하면 필요에 따라 개별 구성 요소를 최적화하고 확장할 수 있으므로 애플리케이션 성능을 더 잘 제어할 수 있습니다.

6. 커뮤니티 및 생태계
Django와 Flask 모두 대규모의 활동적인 커뮤니티와 풍부한 타사 패키지 및 플러그인을 사용할 수 있습니다. Django는 더 오래되었고 더 광범위한 생태계를 가지고 있지만 Flask는 인기가 빠르게 증가하고 있으며 확장 범위도 넓습니다.

Django와 Flask 중에서 선택하는 것은 프로젝트 요구 사항, 개발 경험 및 개인 선호도에 따라 다릅니다. 개발 속도를 높이는 완전한 기능을 갖춘 독창적인 프레임워크가 필요한 경우 Django가 더 탁월한 선택입니다. 처음부터 응용 프로그램을 빌드할 수 있는 가볍고 유연한 프레임워크를 선호한다면 Flask가 더 훌륭한 옵션입니다.


반응형
반응형

뉴스를 빠르게 찾기 위해 Ctrl +F 를 눌러 들어오신 키워드를 검색해보세요!


목차

  1. [팩플] 오픈AI “130조 투자 유치하겠다”... 생성AI ‘돈 싸움’ 시작되나
  2. 애플 1분기 실적 선방…"아이폰이 다 했다"
  3. 실적반등 노리는 삼성…'갤Z 조기출시' 승부수
  4. AI發 가짜 정보 확산…"나 빼고 모두 AI?"
  5. "챗GPT가 패션 코디 추천해요"…옴니어스, 'AI 스타일챗' 개발
  6. KAIST AI 기술, 국제학회 최우수상
  7. 美 이번엔 '기술표준 연합군'… 中 더 옥죈다
  8. "中, 대만 침공땐 세계경제 연1조弗 피해"
  9. [매경춘추] ChatGPT, 이제 서비스다
  10. [클라우드+] 신한은행 배달앱 '땡겨요' 성공 비결은 ◯◯◯◯
  11. 알리바바 클라우드, 아발란체와 메타버스 플랫폼도 협력
  12. NHN클라우드, AI EXPO KOREA 2023 참가… 생활 속에 인공지능과 클라우드 솔루션 선보인다!
  13. 일본, 법적 효력 있는 디지털 유언장 제도 만든다
  14. “검색으로 잘 먹고 살았는데”… 챗GPT 열풍에 위기감 커진 구글·네이버
  15. 미국이 때려도 버티는 中 화웨이…내수·보조금·자체 개발이 비결

헤드라인

[팩플] 오픈AI “130조 투자 유치하겠다”... 생성AI ‘돈 싸움’ 시작되나


요약

챗봇 ChatGPT의 개발자인 OpenAI는 기하급수적인 영업 손실에 직면해 있으며 인공 일반 지능을 개발하기 위해 몇 년 안에 1,000억 달러를 모금할 계획입니다. 지난해 매출 2800만달러에 5억4000만달러 적자를 기록했다. OpenAI는 최근 ChatGPT를 위한 유료 서비스를 시작했으며 Snap 및 Morgan Stanley와 같은 회사에 기업 API를 판매하고 있습니다. 올해 2억 달러 이상의 매출을 올릴 것으로 예상되지만 비용이 엄청나고 컴퓨팅, 인재 및 학습 데이터 세트에 많은 비용을 지불합니다. 이 회사는 제너레이티브 AI 시장을 계속 독점하기 위해 1000억 달러의 추가 투자를 유치할 준비를 하고 있다. OpenAI가 독점이 될 가능성이 높아지면서 AI 학습 데이터에 대한 적정 가격을 얻으려는 움직임과 불법 AI 교육에 대한 법적 조치 등 감시가 강화됐다.


본문

생성형 인공지능(AI) 경쟁이 본격적인 ‘쩐의 전쟁’에 돌입했다. 챗GPT 개발사인 오픈AI는 기하급수적으로 늘어가는 영업 손실에, 130조원대 자금 조달에 나선다. 쩐의 전쟁을 버틴 소수가 미래 시장을 완전히 독점하는 것 아니냐는 우려도 나온다.

무슨 일이야

오픈AI가 지난해 매출 2800만 달러(약372억)에 손실 5억4000만 달러(7171억원)를 기록했다고, 미국 IT 전문 매체 디인포메이션이 4일(현지 시각) 보도했다. 디인포메이션에 따르면 챗GPT를 개발·운영하기 시작한 이후 오픈AI의 손실 규모는 2배로 증가했다. 오픈AI 샘 알트만 최고경영자(CEO)는 최근 내부에 “인공 일반 지능(AGI)을 개발하기 위해서 수년 내에 1000억 달러(약 133조원) 자금을 조달해오겠다”고 밝혔다고도 한다. AGI란 현재 AI의 한계를 극복하고, 인간 수준의 지적 활동을 할 수 있는 AI를 의미한다.

오픈AI는 지난 2월 챗GPT 유료 서비스를 출시했다. 3월부터는 기업용 API를 판매하고 있고, 소셜미디어 스냅과 금융사 모건스탠리 등이 고객에 추가됐다. 테크 업계에서는 오픈AI가 이를 통해 올해 2억 달러(약 2700억원) 이상 매출을 올릴 것으로 본다. 그런데도 비용이 엄청나 운영할수록 손실이 난다는 얘기.

어디에 돈 드나

① 컴퓨팅 비용: 디인포메이션에 따르면, 오픈AI는 2020년 구글에 클라우드 비용으로만 7500만달러(약 1000억원)을 지불했다. 그 이후 오픈AI의 클라우드 사용량은 폭증했다. 현재는 투자사인 마이크로소프트(MS)가 오픈 AI에 클라우드 애저를 제공하는 걸 감안해도, 챗GPT와 그 후속작을 개발·운영하는 데 드는 컴퓨팅 비용은 천문학적이다. 최근 미국 콜로라도대와 텍사스대 연구진은, 챗GPT와 사용자가 질문 25~50개를 주고받으며 대화 1회를 하는 데에 냉각수 물 500㎖가 들어간다고 발표했다.

② 인재 유치: 오픈AI는 구글·메타·애플·아마존 등에서 일하던 AI 개발자 등 고급 인력을 다수 영입하고 있다. 경제 매체 비즈니스인사이더는 지난 2월 “오픈AI가 59명의 구글 직원과 34명의 메타 직원을 데려오는 등, 빅테크 인재들을 ‘빨아들이고’ 있다“라고 보도했다. 실리콘밸리 개발자들의 몸값을 감안하면 인재 영입에도 엄청난 비용을 쓰고 있다는 것.

③ 학습 데이터셋= 챗GPT의 최대 단점은 제한된 학습. 오류 있는 자료나 잘못 분류된 데이터를 AI가 학습할 위험이 있는 데다, AI 스스로 엉뚱한 답변을 지어서 내놓는 이른바 ‘할루시네이션’(환각. AI가 틀린 답변을 맞는 말처럼 제시하는 현상)도 아직 해결되지 않았다. 이를 극복하려면 출처가 분명한, 양질의, 최신 내용의 데이터를 학습하며 AI 모델을 지속 개발해야 하는데, 비용 지출이 필요하다.

이게 왜 중요해

당분간은 AI 개발로 돈 버는 속도보다 돈 쓰는 속도가 빠른 것이 현실이다. 이는 곧 생성 AI의 기술과 사업모델을 고도화할 때까지, 이 경쟁이 철저히 자본 싸움이 될 거라는 의미다.

외신에 따르면 샘 알트만 CEO는 최근 사내에서 “오픈AI는 실리콘밸리 역사상 가장 자본 집약적 스타트업이 될 것”이라고 발언했다. 이미 MS로부터 100억 달러(12조 3000억원) 투자를 약정받은 오픈 AI가 또다시 1000억 달러 투자 유치를 준비하는 배경이다.

디인포메이션은 “신생 기업이 오픈 AI를 따라갈 수 있을지 의문이 제기된다”고 지적했다. 비즈니스인사이더는 “마크 저커버그의 하버드 기숙사에서 시작한 메타 등과는 사뭇 다른 방식으로 이뤄지는 스타트업”이라고 평했다. 앞서 지난 2월 알트만은 미 테크 전문 팟캐스트에 출연해 구글을 “무기력한 검색 독점”으로 지칭한 바 있으나, 오픈AI는 자본을 집약해 생성AI를 독점하는 쪽으로 나아가고 있지 않으냐는 것.

오픈AI가 대규모 자본 투자를 바탕으로 독점 업체로 떠오를 가능성이 부각되자, 견제도 빨라졌다. 대표적인 게 AI 학습용 데이터에 대한 제값 받기 움직임이다. 트위터를 인수한 일론 머스크는 오픈AI가 트위터 데이터를 이용해 불법으로 AI를 훈련했다며 “소송할 시간”이라고 했다. 오픈AI가 로이터·뉴욕타임스·가디언·BBC·월스트리트저널(WSJ) 등의 기사를 참고했다는 사실이 드러난 후 WSJ는 소송을 검토 중이며, 북미 언론사 단체도 조사에 착수했다.


출처

https://n.news.naver.com/article/025/0003278095?sid=105 

 

[팩플] 오픈AI “130조 투자 유치하겠다”... 생성AI ‘돈 싸움’ 시작되나

생성형 인공지능(AI) 경쟁이 본격적인 ‘쩐의 전쟁’에 돌입했다. 챗GPT 개발사인 오픈AI는 기하급수적으로 늘어가는 영업 손실에, 130조원대 자금 조달에 나선다. 쩐의 전쟁을 버틴 소수가 미래

n.news.naver.com



헤드라인

애플 1분기 실적 선방…"아이폰이 다 했다"

스마트폰 시장 침체에도 선전
전체 매출은 2분기 연속 감소


요약

애플이 올해 1분기 주력 제품인 아이폰의 판매가 예상보다 양호하다고 보고했다. 회사는 1분기 매출이 전년 동기 대비 2.5% 감소한 948억4000만 달러, 당기순이익은 3.4% 감소한 241억6000만 달러를 기록했다고 발표했다. 매출과 순이익은 시장 예상치를 상회했지만 전체 매출은 지난해 4분기에 이어 2분기 연속 감소했다. 다만 아이폰 매출은 지난해 동기 대비 1.5% 늘어난 513억3000만달러로 시장 예상치를 상회했다. 아이폰의 하이엔드 전략과 인도, 인도네시아, 중남미, 중동 등 신흥시장에서의 판매 확대가 실적에 힘입은 것이다. 팀 쿡 애플 최고경영자(CEO)는 회사가 시장에 주력하고 있는 인도에서 안드로이드에서 아이폰으로 전환하는 사용자들의 매출이 호조를 보이고 있다고 말했다. 그러나 Mac 및 iPad와 같은 다른 장치의 판매는 경기 침체의 영향을 받았습니다. iCloud, Apple Music, App Store 및 TV+ 스트리밍을 포함하는 서비스 사업부에서 회사의 매출은 5.5% 증가한 209억 1000만 달러를 기록했습니다. 애플은 또한 900억 달러 규모의 자사주 매입 계획을 발표하고 분기 배당금을 주당 24센트로 4% 인상했습니다.


본문

애플의 대표 제품인 아이폰이 올 1분기에 기대 이상의 실적을 냈다. 인도 등 신흥시장에서 판매가 늘었고 고가 모델 수요가 탄탄했던 덕분이다. 단 애플의 1분기 전체 매출은 두 분기 연속 감소했다.

 

애플은 1분기(자체 2023회계연도 2분기) 매출이 948억4000만달러로 지난해 같은 기간보다 2.5% 감소했다고 4일(현지시간) 발표했다. 순이익은 3.4% 줄어든 241억6000만달러였다. 매출과 순이익이 시장 추정치를 웃돌긴 했지만 외형 자체는 줄었다. 이로써 애플 매출은 지난해 4분기에 이어 두 분기 연속으로 감소했다. 애플의 분기 매출이 연속으로 줄어든 건 10년 만에 세 번째이며 코로나19 팬데믹(전염병 대유행) 후로는 처음이다.

하지만 애플의 대표 제품인 아이폰이 거둔 성과는 돋보였다는 평이다. 이 기간 아이폰 매출은 513억3000만달러로 전년 동기 대비 1.5% 증가했다. 시장 추정치(487억달러)를 웃돌았다. 1분기 세계 스마트폰 출하량이 14.6% 감소(시장조사업체 IDC 추정)했다는 점을 감안할 때 아이폰 매출이 1.5% 늘어난 건 상당한 성과라는 게 중평이다. 인도 인도네시아 라틴아메리카 중동 등 신흥시장에서 아이폰 판매가 늘었다. 팀 쿡 애플 최고경영자(CEO)는 “인도에서 스위처(안드로이드에서 아이폰으로 전환하는 사용자)와 최초 구매자 지표가 매우 좋다”고 했다. 애플은 지난달 인도에서 첫 번째 소매점을 여는 등 인도 시장에 힘을 쏟고 있다. 아이폰 고급화 전략도 효과적이었다는 분석이다. 컨슈머인텔리전스리서치파트너스에 따르면 최고가 모델인 아이폰14 프로맥스가 전체 아이폰 매출의 24%를 차지했고, 아이폰14 프로는 22%로 집계됐다. 아이폰 평균 판매가격은 2019년 802달러에서 지난 분기 988달러로 23.2% 상승했다.

다만 아이폰을 제외한 다른 기기는 경기 둔화 여파를 피하지 못했다. PC 사업부인 맥의 매출은 31%, 아이패드 매출은 13% 줄었다. 대신 서비스 사업 부문의 매출은 209억1000만달러로 5.5% 증가했다. 서비스 사업에는 아이클라우드, 애플뮤직, 앱스토어, TV+ 스트리밍 등이 있다.

이날 애플은 900억달러의 자사주 매입 계획을 발표했다. 분기 배당금도 주당 24센트로 전년 동기 대비 4% 인상하기로 했다. 실적 발표일에 애플 주가는 전날보다 0.99% 하락한 165.79달러로 마감했다가 시간외거래에선 2.49% 상승했다.


출처

https://n.news.naver.com/mnews/article/015/0004841210

 

애플 1분기 실적 선방…"아이폰이 다 했다"

이 기사는 국내 최대 해외 투자정보 플랫폼 한경 글로벌마켓에 게재된 기사입니다. 애플의 대표 제품인 아이폰이 올 1분기에 기대 이상의 실적을 냈다. 인도 등 신흥시장에서 판매가 늘었고 고

n.news.naver.com



헤드라인

실적반등 노리는 삼성…'갤Z 조기출시' 승부수

폴드·플립 5, 7월말 공개

예년보다 2주 정도 앞당겨
아이폰15 나오기 전 실적 극대화
구글·샤오미 등 견제 포석도


요약

삼성전자가 '신제품 출시 효과'를 극대화하고 경쟁사인 애플의 아이폰15 출시와 경쟁하기 위해 평소보다 2주 빠른 7월 말 프리미엄 스마트폰 '갤럭시Z 폴드'와 '플립5'를 출시한다고 밝혔다. 9월에. 이 회사는 폴더블폰 시장에서 선두를 유지하고 최근 새로운 폴더블폰을 출시한 Google, Huawei, Xiaomi, Oppo, Vivo와 같은 경쟁업체를 물리치기를 희망합니다. 삼성은 하드웨어 혁신을 통해 '초격차'를 유지하고 갤럭시Z플립5의 외장 화면을 플립4보다 1.8배 늘어난 8.6cm(3.4인치)로 늘릴 계획이다. 접히는 부분의 주름을 최소화하고 공간을 줄이기 위해 물방울 경첩을 적용하여 접는 부분의 디자인. 삼성전자는 갤럭시 신제품을 조기 출시해 스마트폰 교체 수요를 흡수하고 3분기 매출을 늘려 2분기 영업적자를 만회하겠다는 방침이다.


본문

삼성전자가 프리미엄 스마트폰 갤럭시 Z 폴드·플립5의 공개 시점을 오는 7월 말로 결정했다. 예년보다 2주 정도 앞당겼다. 9월 경쟁사 애플의 아이폰15 출시를 앞둔 상황에서 갤럭시 판매 시점을 앞당겨 ‘신제품 출시 효과’를 극대화하려는 전략으로 분석된다. 구글 등 폴더블 스마트폰을 출시하고 있는 경쟁사들을 견제하려는 목적도 있다. 업계에선 올해 2분기 영업적자가 유력한 삼성전자가 3분기 실적을 끌어올리기 위해 ‘초강수’를 뒀다는 평가가 나온다.

 

5일 산업계에 따르면 삼성전자 스마트폰을 담당하는 MX(모바일경험)사업부는 갤럭시 Z 폴드·플립5의 공개 시점을 7월 넷째 주로 잠정 결정했다. 갤럭시 Z4 시리즈가 2022년 8월 10일, Z3 제품이 2021년 8월 11일 공개된 것을 감안하면 2주 정도 앞당긴 것이다. 통상 제품 공개 후 판매 시작까지 보름 정도 걸리는 것을 감안할 때 소비자들은 8월 중순께 갤럭시 Z5 폴더블폰을 구매할 수 있을 것으로 전망된다.

MX사업부는 ‘언팩’으로 불리는 공개 행사를 한국에서 여는 방안을 검토하고 있다. 개최지로 서울, 부산 등이 거론된다. 그동안 삼성전자는 미국 뉴욕이나 샌프란시스코에서 언팩 행사를 열었다. 갤럭시 언팩 행사에 전 세계 미디어의 관심이 집중되는 만큼 세계 박람회 유치 등에도 도움이 될 것이란 분석이 나온다.

출시 시점을 앞당기는 이유는 올해 3분기 실적을 끌어올리기 위한 것으로 분석된다. 금융투자업계에선 삼성전자가 반도체시장의 불황 여파로 올 2분기 영업적자를 기록할 것이란 전망이 나오고 있다. 3분기에는 ‘반전의 계기’가 필요한 상황이다. 갤럭시 Z5 시리즈의 공개·출시 시점을 2주 앞당기면 3분기 판매 실적이 더 늘어날 것으로 예상된다.

신제품 효과 극대화를 위한 포석도 깔려 있다. 오는 9월 아이폰15 출시를 앞두고 최대한 이른 시점에 갤럭시 신제품을 출시해 스마트폰 교체 수요를 흡수하겠다는 계산이다. 시장조사업체 DSCC의 로스 영 최고경영자(CEO)는 최근 트위터에 “플립5의 7월 생산량이 플립4 대비 크게 증가할 것으로 예상된다”며 “조기 출시가 유력하다는 의미”라고 적었다. 또 “아이폰15 출시일과 거리를 두는 것은 좋은 전략이 될 수 있다”고 평가했다.

경쟁사들을 견제하기 위한 목적도 있다. 삼성전자의 지난해 폴더블폰 시장 점유율(스트래티지애널리틱스 기준)은 76.9%로 압도적 1위다. 하지만 최근 구글, 화웨이, 샤오미, 오포, 비보 등이 공격적으로 폴더블폰 신제품을 출시하면서 격차가 좁혀질 것이란 관측도 나온다.

삼성전자는 폴더블폰의 하드웨어 혁신을 통해 ‘초격차’를 유지할 계획이다. 외부 화면을 키워 디자인을 개선하고 사용자의 편의성을 높이는 게 대표적 사례로 꼽힌다. 정보기술(IT)업계에선 갤럭시 Z 플립5의 외부 화면 대각선 길이가 8.6㎝(3.4인치)로, 4.8㎝(1.9인치)인 플립4의 1.8배 수준이 될 것이란 관측이 나온다.

약점으로 꼽혔던 접히는 부분의 성능과 디자인도 대폭 개선할 전망이다. 삼성전자는 기존 U자형 힌지(경첩) 대신 물방울 힌지를 적용해 접히는 부분의 주름을 최소화하고 접었을 때 생기는 공간을 줄일 것으로 예상된다.


출처

https://n.news.naver.com/mnews/article/015/0004841192

 

실적반등 노리는 삼성…'갤Z 조기출시' 승부수

삼성전자가 프리미엄 스마트폰 갤럭시 Z 폴드·플립5의 공개 시점을 오는 7월 말로 결정했다. 예년보다 2주 정도 앞당겼다. 9월 경쟁사 애플의 아이폰15 출시를 앞둔 상황에서 갤럭시 판매 시점을

n.news.naver.com



헤드라인

AI發 가짜 정보 확산…"나 빼고 모두 AI?"

AI가 글을 썼다는 인장 급증
가짜 리뷰, 가짜 책 버젓이 유통
인장 삭제되면 더 큰 혼란 생겨
AI 성능 저하로도 이어질 듯


요약

인공지능(AI)이 생성한 '쓰레기 데이터'가 인터넷상에서 확산될 가능성에 대한 우려가 커지고 있다. 예를 들면 생성 AI 모델을 사용하여 저품질 책을 인쇄하거나 소셜 미디어 및 쇼핑 웹사이트에 가짜 리뷰를 작성하는 것이 있습니다. AI 언어 모델로'라는 문구가 AI 관련 온라인 커뮤니티에서 화제가 되면서 질의 응답 초반부에 자주 등장한다. 일부 온라인 리뷰와 댓글에는 이 문구가 포함되어 있으며 아마존 온라인 서점에서 판매 중인 책에서도 발견되었습니다. 그러한 관행은 비윤리적인 것으로 간주되지만 불법은 아닙니다. 국내에서는 온라인 글쓰기에서 생성 AI의 흔적이 드물지만 ChatGPT와 같은 LLM의 한국어 능력이 향상됨에 따라 증가할 것으로 예상됩니다. AI가 만든 콘텐츠의 문제는 온라인 정보의 품질과 신뢰성에 대한 우려를 불러일으키고 있으며, AI가 만든 콘텐츠는 사람이 만든 콘텐츠와 구별하기 어려울 수 있다는 사실이 문제입니다. AI가 만든 콘텐츠를 식별할 수 있는 AI 개발은 아직 초기 단계로 현재 성공 가능성은 낮다. "쓰레기 데이터"의 확산을 방지하고 온라인 정보의 품질을 향상시키기 위해 고품질 콘텐츠를 사용하여 AI 모델을 훈련시키는 것이 중요합니다.


본문

생성 인공지능(AI)이 만든 ‘가비지(쓰레기) 데이터’가 인터넷 공간을 오염시킬 수 있다는 우려가 현실화하고 있다. 오픈AI의 챗봇 ‘챗GPT’와 같은 생성 AI를 활용해 수준 이하의 책을 찍어내거나 소셜미디어, 쇼핑몰 등에 거짓 리뷰를 작성하는 사례가 늘고 있다.

5일 업계에 따르면 최근 해외 AI 관련 커뮤니티에선 ‘AI 언어 모델로서(As an AI language model)’라는 문구가 화제다. 챗GPT에 금지된 질문을 하거나 답하기 어려운 주관적인 의견을 요청할 때 답변 서두에 쓰이는 문구다. 엉뚱하게 이 문구가 쇼핑몰의 리뷰나 게시판 댓글 같은 곳에서 발견되는 빈도가 늘고 있다.

미국의 정보기술(IT) 전문 매체인 더 버지는 한 보안 엔지니어가 발견한 아마존의 리뷰를 예로 들었다. 리뷰에는 “AI 언어 모델로서 이 제품을 개인적으로 사용하지 않았지만, 기능과 고객 리뷰를 바탕으로 자신 있게 5점을 줄 수 있습니다”라고 적혀 있다. 한 핀란드의 전자제품 매장 웹사이트에는 영어를 핀란드어로 번역하다 실패한 흔적이 남았다. 상품 설명에 ‘미안하지만, AI 언어 모델로서 문맥 없이 이 문구를 번역할 수 없으니 추가 정보를 달라’는 문구가 등장한다.

생성 AI를 활용해 대량으로 책을 찍어내는 사례도 나왔다. 아마존 온라인 서점에서 판매 중인 한 책에서 ‘AI 언어 모델로서’라는 구절이 발견됐다. 이 책의 저자는 올해 2월부터 3개월 동안 AI, 파이선, 데이터 사이언스 등 기술 관련 서적을 40권가량 발간했다. 더 버지는 “이런 종류의 저급 AI 제품을 판매하는 것은 파렴치하지만 불법은 아니다”고 꼬집었다.

한국어로 된 리뷰나 온라인 글에선 이 같은 생성 AI의 ‘흔적’이 아직 드물지만 안심하긴 이르다는 게 업계의 설명이다. 한 IT 기업 관계자는 “챗GPT의 한국어 실력이 빠르게 늘고 있다”며 “국내 기업들도 한국어 특화 초거대 AI를 준비하고 있는 만큼 곧 이런 문제가 수면 위로 떠오를 것”이라고 말했다.

AI 언어 모델로서’란 문구는 AI가 글을 썼다는 사실을 드러내는 일종의 ‘인장’이다. 이 같은 문구가 인위적인 방법 등으로 삭제된 글은 더 위험하다고 업계는 평가했다. 생성 AI를 통해 작성된 글이 얼마나 빠른 속도로 온라인 공간을 차지하고 있는지 누구도 알 수 없기 때문이다. 생성 AI의 발전에 따라 사람들이 온라인 공간에서 만나는 다른 사람을 ‘봇’으로 의심하는 일이 늘었다는 게 더 버지의 지적이다.

GPT와 같은 대규모 언어 모델(LLM)은 참과 거짓을 따지지 않는다. 주어진 텍스트에 가장 잘 어울리는 단어를 나열하는 방식이다. 더 버지 관계자는 “생성 AI의 ‘환각’ 문제가 계속되는 한 AI로 만든 콘텐츠에 대한 의심이 계속될 수밖에 없다”며 “장기적으로 AI의 성능에도 영향을 미칠 것”이라고 했다. 양질의 콘텐츠를 활용해 AI 모델을 고도화해야 하는데 AI가 만든 불량 데이터를 이용할 경우 성능이 떨어지게 된다.

AI가 만든 콘텐츠를 찾아내는 AI도 등장했지만 갈 길이 멀다. 오픈AI는 지난 1월 AI가 쓴 글을 찾아내는 ‘클래시파이어’를 공개했지만 식별 성공 확률은 26%에 그쳤다.


출처

https://n.news.naver.com/mnews/article/015/0004841195

 

AI發 가짜 정보 확산…"나 빼고 모두 AI?"

생성 인공지능(AI)이 만든 ‘가비지(쓰레기) 데이터’가 인터넷 공간을 오염시킬 수 있다는 우려가 현실화하고 있다. 오픈AI의 챗봇 ‘챗GPT’와 같은 생성 AI를 활용해 수준 이하의 책을 찍어내거

n.news.naver.com



헤드라인

"챗GPT가 패션 코디 추천해요"…옴니어스, 'AI 스타일챗' 개발

AI 스타트업 라운드테이블

개인 맞춤형 쇼핑 솔루션도 제공
원지랩스, AI 타로카드 앱 출시


요약

지난 5월 4일 열린 AI 스타트업 라운드테이블 행사에서 AI 기반 온라인 커머스 솔루션 기업 옴니우스 전재영 대표는 AI가 소비자의 쇼핑몰 이용 패턴을 분석해 맞춤형 쇼핑 정보를 제공함으로써 쇼핑몰 매출 증가. 옴니우스는 개인 맞춤형 쇼핑 솔루션 '옴니커머스'를 개발해 옴니우스의 인공지능과 오픈AI의 '챗GPT'를 결합해 사용자의 궁금증에 맞는 패션 스타일을 제안하는 패션 스타일 추천 서비스 '스타일챗'을 운영하고 있다. 다양한 제너레이티브 AI 서비스를 개발하는 스타트업 원지랩스(OneG Labs)는 OpenAI의 AI 모델 GPT를 활용한 타로카드 앱 '마이타로(My Taro)'와 AI를 활용해 기업의 홍보용 보도자료 작성을 돕는 서비스 'AI PR'을 선보였다. 물류 스타트업 브이투브이(V2V)는 AI와 빅데이터를 활용한 최적의 경로를 통한 택배 서비스를 제공하고 있으며, 최근 당일배송 서비스 '투데이'를 서울 전 지역으로 확대했다. 서울 곳곳에 작은 창고를 세워 배송 방식을 개선하겠다는 것이다. AI 스타트업 라운드테이블 행사는 유망한 AI 스타트업과 투자자를 연결하기 위해 마련됐으며, 한국경제 AI미래포럼(AIFF)과 캡스톤파트너스가 주최했다.


본문

“인공지능(AI)이 소비자의 쇼핑몰 이용 패턴을 분석해 맞춤형 쇼핑 정보를 제공하죠.”

AI 기반 온라인 상거래 솔루션업체 옴니어스의 전재영 대표는 지난 4일 열린 ‘AI 스타트업 라운드테이블’ 행사에서 “맞춤형 정보가 소비자의 온라인 쇼핑몰 체류 시간을 늘려 쇼핑몰 매출이 증가했다”고 설명했다. 한국경제신문 AI미래포럼(AIFF)과 캡스톤파트너스가 주최한 이번 행사는 유망 AI 스타트업과 투자자를 이어주기 위해 마련됐다.

옴니어스는 개인화 쇼핑 솔루션 ‘옴니커머스’를 개발했고, 패션 스타일 추천 서비스 ‘스타일챗’을 운영하고 있다. 옴니커머스는 쇼핑몰 사업자 등 기업 고객에 제공하는 AI 기술이다. AI가 다양한 상품 이미지에서 제품의 각종 속성을 파악해 개인 맞춤형 쇼핑 정보를 소비자에게 제공한다. 에이블리, 제페토 등이 옴니어스의 고객사다. 전 대표는 “스타일챗은 패션 정보 데이터를 학습한 옴니어스의 AI에 오픈AI사의 ‘챗GPT’를 결합한 서비스로 이용자의 질문에 적합한 패션 스타일을 제안한다”고 말했다.

원지랩스는 각종 생성형 AI 서비스를 개발하는 스타트업이다. 곽근봉 원지랩스 대표는 “기업 규모가 작은 스타트업은 많은 비용이 들어가는 AI 모델을 개발하는 것보다 기존 AI 기술을 활용해 시장이 요구하는 제품을 내놓는 전략이 필요하다”고 강조했다. 원지랩스는 오픈AI AI 모델 GPT를 활용한 타로카드 앱 ‘마이타로’를 올 3월 선보였다. 기존 온라인 타로 서비스가 준비된 일부 콘텐츠만 제공하는 것과 달리 사용자가 궁금한 모든 질문에 실시간으로 적합한 답변을 내놓는다. 지난주 유료 콘텐츠를 추가했다. 신규 이용자의 10%가량이 유료 콘텐츠를 사용할 정도로 호응이 좋다고 곽 대표는 설명했다. 원지랩스는 AI를 활용해 기업의 홍보용 보도 자료 작성을 돕는 서비스인 ‘AI피알’도 최근 출시했다.

브이투브이는 물류 전문 스타트업이다. AI, 빅데이터 등을 활용해 최적 경로의 택배 서비스를 제공하고 있다. 최근에는 당일배송 서비스 ‘투데이’를 서울 전 지역으로 확대했다. 권민구 브이투브이 이사는 “기존 택배 시스템은 수도권에서 발송하고 받는 물건도 충북 옥천 지역 등 수도권 외곽의 대형 물류창고를 통해 물류를 처리하기 때문에 택배 처리 비용과 시간을 낭비한다”고 지적했다. 브이투브이는 서울시 대중버스의 효율적인 운행 체계를 참조해 배송 방식을 개선하고 있다. 권 이사는 “버스 정류장처럼 서울 곳곳에 소규모 창고를 마련해 물류 흐름의 속도를 높였다”고 말했다.


출처

https://n.news.naver.com/mnews/article/015/0004841198

 

"챗GPT가 패션 코디 추천해요"…옴니어스, 'AI 스타일챗' 개발

“인공지능(AI)이 소비자의 쇼핑몰 이용 패턴을 분석해 맞춤형 쇼핑 정보를 제공하죠.” AI 기반 온라인 상거래 솔루션업체 옴니어스의 전재영 대표는 지난 4일 열린 ‘AI 스타트업 라운드테이블

n.news.naver.com



헤드라인

KAIST AI 기술, 국제학회 최우수상


요약

KAIST 홍승훈 교수가 이끄는 컴퓨터공학부가 머신러닝 분야의 권위 있는 국제학술대회인 ICLR(International Society for Expressive Learning) 2023에서 최우수논문상을 수상했다. 홍 교수와 박사과정 김동균, 마이크로소프트 관계자 등으로 구성된 연구팀은 인공지능이 물체를 감지하고 분할하는 데 필수적인 기술인 '픽셀 라벨링' 문제를 해결하기 위해 '비주얼 토큰 매칭'이라는 방법론을 제안했다. 자세와 깊이, 3D 재구성을 수행합니다. ICLR 최우수논문상은 인공지능(AI) 분야에서 가장 권위 있는 상 중 하나로, 한국인이 이 상을 받은 것은 이번이 처음이다.


본문

KAIST는 홍승훈 전산학부 교수가 이끄는 연구팀이 이달 1~5일 열린 기계학습 분야 국제학술대회 ‘표현학습 국제학회(ICLR) 2023’에서 최우수 논문상을 받았다고 5일 밝혔다. ICLR은 인공지능(AI) 관련 가장 권위 있는 학회 중 하나다.

홍 교수와 김동균 박사과정 연구원, 마이크로소프트 관계자 등으로 구성된 연구팀은 컴퓨터 비전 분야의 핵심인 ‘픽셀 레이블링’ 문제를 수십 개의 적은 데이터로 광범위하게 해결할 수 있는 방법론 ‘비주얼 토큰 매칭’을 제안했다.

픽셀 레이블링은 AI가 물체 검출과 분할, 자세와 깊이 추정, 3차원 복원 등을 할 때 반드시 필요한 기술이다. 이번 ICLR 최우수 논문상은 총 1754편 논문 중 점수가 가장 높은 상위 4편이 받았다. 한국인이 이 상을 받은 것은 처음이다.


출처

https://n.news.naver.com/mnews/article/015/0004841196

 

KAIST AI 기술, 국제학회 최우수상

KAIST는 홍승훈 전산학부 교수(왼쪽)가 이끄는 연구팀이 이달 1~5일 열린 기계학습 분야 국제학술대회 ‘표현학습 국제학회(ICLR) 2023’에서 최우수 논문상을 받았다고 5일 밝혔다. ICLR은 인공지능(A

n.news.naver.com



헤드라인

美 이번엔 '기술표준 연합군'… 中 더 옥죈다

"같은 마음 가진 나라들과 공조
첨단기술 국제표준 마련할 것"
한층 격화되는 기술 패권 경쟁
AI·양자 '표준전쟁'으로 확전


요약

미중 대결은 이제 인공지능(AI), 생명공학, 양자 등 첨단 분야로 확대되고 있다. 중국의 기술 발전에 대응하기 위해 백악관은 AI, 생명 공학, 양자 및 청정 에너지와 같은 첨단 기술 분야에서 차세대 국제 표준을 선도하기 위한 국가 전략을 발표했습니다. 이 전략은 민간 부문 및 같은 생각을 가진 국가와 협력하여 최첨단 기술에 대한 차세대 국제 표준을 준비하는 것을 목표로 합니다. NIST(National Institute of Standards and Technology)는 반도체 지원법과 표준 개발을 연계해 표준 정보 포털을 제공하고, 미국은 인도태평양과 일본·인도·호주 등 쿼드 국가와 협력한다. 또한 백악관은 국가 AI 연구소를 설립하고 AI 남용 및 개인 정보 보호에 대한 정책 지침을 마련하는 등 연구 개발에 1억 4000만 달러를 투자할 계획이다. 미 상원 민주당 의원들도 중국과의 전략적 경쟁을 주도하기 위해 '중국경쟁 2.0' 법안을 준비하고 있다.


본문

◆ 美中 기술표준 전쟁 ◆

반도체, 전기차를 둘러싼 기술 패권 경쟁에 이어 미국과 중국의 대립·갈등이 인공지능(AI), 생명공학, 양자(퀀텀) 등 첨단기술 분야로 확대되고 있다. 차세대 첨단산업은 한국도 정부와 기업이 사활을 걸고 육성하는 분야여서 갈수록 격해지는 미·중 간 대립이 큰 영향을 미칠 수 있다는 전망이 나온다.

4일(현지시간) 미국 백악관은 AI, 생명공학, 양자, 청정에너지 등 첨단기술 분야에서 중국을 견제하기 위해 차세대 국제표준을 주도하는 국가 전략을 발표했다.

미국 정부는 브리핑에서 "미국 경제에 도움이 되지 않는 다른 지역에서 국제표준이 개발되고 있다"며 "우위를 유지하기 위해 표준 마련에 대한 우리의 약속을 새로 정비할 필요를 느낀다"고 밝혔다. 이어 "민간부문과 협력하고 같은 마음을 가진 나라들과 공조해 첨단기술의 차세대 국제표준을 마련할 것"이라고 강조했다.

이와 관련해 백악관은 앞으로 국립표준기술연구소(NIST)가 반도체지원법과 표준 발전을 연계해서 표준 정보 포털을 제공할 것이라고 설명했다. 국제표준 공조와 관련해서는 인도·태평양 및 일본·인도·호주 등 쿼드 국가들과 우선적으로 협력하기로 했다. 미국 상무부에 따르면 세계 무역의 93%는 국제표준에 직접적으로 영향을 받는다.

특히 조 바이든 미국 대통령은 이날 카멀라 해리스 부통령 주재로 백악관에서 열린 민관 AI 회의에 깜짝 방문한 뒤 AI가 국가안보에 미치는 영향을 점검해달라고 요청했다.

백악관은 국립AI연구소를 설립해서 연구개발을 하는 데 1억4000만달러를 투자한다고 발표했다. AI 남용과 개인정보 보호 같은 정책지침도 마련하기로 했다.

이런 가운데 미국 상원에서 민주당 소속 의원들은 중국과의 전략적 경쟁에서 앞설 수 있도록 기존 반도체과학법에 이어 '중국 경쟁 2.0' 법안을 준비하고 있다. 미국이 중국을 겨냥한 수출통제를 넘어 기술표준 패권 경쟁으로 확전에 나서는 양상이다.


출처

https://n.news.naver.com/mnews/article/009/0005126270

 

美 이번엔 '기술표준 연합군'… 中 더 옥죈다

"같은 마음 가진 나라들과 공조 첨단기술 국제표준 마련할 것" 한층 격화되는 기술 패권 경쟁 AI·양자 '표준전쟁'으로 확전 ◆ 美中 기술표준 전쟁 ◆ 반도체, 전기차를 둘러싼 기술 패권 경쟁에

n.news.naver.com



헤드라인

"中, 대만 침공땐 세계경제 연1조弗 피해"

헤인스 美 국가정보국장


요약

에이브릴 헤인즈 미국 정보국장은 중국이 대만을 침공해 TSMC와 같은 기업의 반도체 생산을 중단할 경우 세계 경제가 연간 최대 1조 달러의 피해를 입을 수 있다고 경고했다. 대만을 둘러싼 지정학적 위험이 글로벌 공급망에 미칠 잠재적 영향에 대해 구체적인 금액이 제시된 것은 이번이 처음입니다. Haynes는 TSMC가 전 세계 거의 모든 전자 장치에 사용되는 고급 반도체 칩의 약 90%를 생산한다고 말했습니다. 그는 또 미국 GDP가 영향을 받을 것이며, 중국이 반도체를 확보하지 못하면 더 큰 영향을 받을 것이라고 내다봤다.


본문

중국이 대만을 침공해 대만에서 반도체 생산이 중단되면 세계 경제가 연간 최대 1조달러(약 1300조원) 규모 피해를 입을 수 있다고 미국 정보당국 수장이 밝혔다. 대만을 둘러싼 지정학적 리스크가 글로벌 공급망에 미치는 영향이 구체적인 금액으로 분석된 것은 이번이 처음이다.

미국 정부 내 16개 정보기관을 총괄하는 국가정보국(ODNI)의 애브릴 헤인스 국장은 4일(현지시간) 상원 군사위원회 청문회에 출석해 "중국이 대만을 침공하면 TSMC에서 반도체 칩 생산이 중단돼 세계 경제에 엄청난 타격을 줄 것"이라며 "그 영향이 처음 몇 년 동안은 연간 6000억달러에서 최대 1조달러 규모가 될 것"이라고 전망했다.

헤인스 국장은 "대만 TSMC가 전 세계 거의 모든 전자기기에 들어가는 첨단 반도체 칩의 90%가량을 생산한다"며 "생산이 중단되면 그 공백을 채우기까지 막대한 재정적 영향이 있을 것"이라고 경고했다. 그는 미국 국내총생산(GDP)도 영향을 받을뿐더러 중국이 반도체를 구하지 못하면 중국 GDP에는 더 큰 영향이 있을 것으로 전망했다.


출처

https://n.news.naver.com/mnews/article/009/0005126243

 

"中, 대만 침공땐 세계경제 연1조弗 피해"

헤인스 美 국가정보국장 중국이 대만을 침공해 대만에서 반도체 생산이 중단되면 세계 경제가 연간 최대 1조달러(약 1300조원) 규모 피해를 입을 수 있다고 미국 정보당국 수장이 밝혔다. 대만을

n.news.naver.com



헤드라인

[매경춘추] ChatGPT, 이제 서비스다


요약

AI 산업은 2016년 3월 알파고 모멘텀 이후 성장했지만 킬러 애플리케이션이 없어 기대만큼 성장하지는 못했다. 그러나 1억 명 이상의 사용자를 확보한 OpenAI의 ChatGPT는 모든 산업의 파괴자로 간주되며 그 자체로 킬러 애플리케이션입니다. ChatGPT는 최신 지식이 부족하지만 정보를 종합하고 추론하는 데 능숙한 언어 모델입니다. ChatGPT를 최신 상태로 유지하고 제대로 응답하려면 시맨틱 검색, 프롬프트 엔지니어링, 오케스트레이터 및 ChatGPT와 같은 대규모 언어 모델(LLM)이 필요합니다. ChatGPT와 같은 세 가지 주요 LLM 기반 AI 산업 생태계가 있습니다. 첫 번째 생태계는 OpenAI, Microsoft, Google과 같이 LLM 자체를 제공하는 원천 기술 회사입니다. 두 번째 생태계는 LLM이 고객 요청에 따라 작동하도록 개선하는 서비스 회사입니다. 세 번째 생태계는 특정 도메인에서 애플리케이션을 제공하는 회사입니다. 실리콘밸리에는 Scale AI, Distyl AI, Quantiphi 등 서비스 기업이 떠오르고 있으며 LG CNS도 서비스 기업이다. 한국에 더 많은 서비스 기업이 생겨 함께 국가경쟁력을 높일 것으로 기대된다.


본문

2016년 3월을 생생히 기억한다. 알파고가 사람을 이겼다. 알파고가 뭔가 세상에 파란을 불러일으키지 않을까라고 상상하고 있던 시기였다. 이른바 '알파고 모멘텀' 이후 AI산업은 발전했지만, 기대만큼 성장했다고 보긴 어렵다. 킬러 애플리케이션(Killer Application)이 나오지 않았기 때문이다. AI챗봇이 상용화됐지만, 알파고가 줬던 놀라움만큼은 아니다.

2022년 11월 또 다른 모멘텀이 등장했다. OpenAI의 ChatGPT다. 지금은 1억명 이상이 ChatGPT를 사용하고 있다. 'ChatGPT 모멘텀'이라고 불릴 만하다. ChatGPT가 알파고와 다른 점은 대중성이다. TV를 통해 알파고를 접했다면, ChatGPT는 내가 직접 체험할 수 있다.

많은 사람들이 ChatGPT는 모든 산업에 지각변동을 불러일으킬 것으로 기대한다. ChatGPT는 그 자체로 킬러 애플리케이션이다. ChatGPT는 알려진 바와 같이 2021년 9월까지 데이터만으로 학습했다. 그 이후 정보는 반영이 안 됐다. ChatGPT만으로는 우리가 원하는 답변을 얻기 힘들 수 있다. OpenAI는 ChatGPT를 왜 이렇게 만들었을까?

ChatGPT는 '언어 모델'이다. '지식 모델'은 아니다. ChatGPT는 정보를 종합하고 추론하는 능력은 매우 우수하지만, 최신 지식은 부족하다. 세상 물정은 모르지만, 매우 똑똑한 친구다. 이 친구에게 나도 이해하기 어려운 최신 논문을 주고, 해석을 부탁해 볼 수 있지 않을까? ChatGPT에 최신 정보를 전달하고, ChatGPT가 제대로 답변하도록 지시하는 일은 중요하다. 다양한 산업에 ChatGPT를 적용하기 위해서도 그렇다. ChatGPT가 추론할 정보를 찾아오는 시맨틱 검색(Semantic Search), 정확한 지시를 하는 프롬프트 엔지니어링(Prompt Engineering), 모든 과정을 조율하는 오케스트레이터(Orchestrator), ChatGPT와 같은 대형 언어 모델(Large Language Model·LLM)을 니즈에 맞게 튜닝하는 일 등 서비스 영역에서 새로운 사업 기회를 찾을 수 있다.

ChatGPT와 같은 LLM 기반의 AI산업 생태계는 크게 세 개다. 첫째, OpenAI, 마이크로소프트, 구글과 같이 LLM 자체를 제공하는 원천기술 기업. 둘째, LLM이 고객 요청에 맞게 작동하도록 개선하는 서비스 기업. 셋째, 특정 도메인에서 애플리케이션을 제공하는 기업이다. 현재 LLM을 만드는 빅테크 기업들이 주목받고 있지만, 실리콘밸리에서는 Scale AI(스케일 AI), Distyl AI(디스틸 AI), Quantiphi(퀀티파이) 등 서비스 기업들이 부상 중이다. 실제 업무에 활용하기엔 원천기술만으로는 부족하기 때문이다. LG CNS도 서비스 기업이다. 우리나라에서도 많은 서비스 기업이 나와서 함께 국가 경쟁력을 높여 나가기를 기대해 본다.


출처

https://n.news.naver.com/mnews/article/009/0005126193

 

[매경춘추] ChatGPT, 이제 서비스다

2016년 3월을 생생히 기억한다. 알파고가 사람을 이겼다. 알파고가 뭔가 세상에 파란을 불러일으키지 않을까라고 상상하고 있던 시기였다. 이른바 '알파고 모멘텀' 이후 AI산업은 발전했지만, 기

n.news.naver.com



헤드라인

[클라우드+] 신한은행 배달앱 '땡겨요' 성공 비결은 ◯◯◯◯

신한은행, 배달 앱 '땡겨요' 클라우드로 효율성 극대화...2019년부터 퍼블릭 클라우드 도입
AWS 등과 협력해 AM 표준체계 정립 등 클라우드 네이티브 환경 구축


요약

신한은행 한상훈 ICT운영실장이 AWS 서밋 서울에서 음식 주문 플랫폼 땡겨요의 성공 사례를 공유했다. 그는 2016년부터 은행이 효율성을 극대화하기 위해 프라이빗 클라우드와 퍼블릭 클라우드를 결합한 클라우드 우선 전략을 채택한 데 플랫폼의 성공을 돌렸습니다. 은행 전체 시스템의 약 40%가 클라우드에서 운영되며 퍼블릭 클라우드 전환율은 4%입니다. 이 은행은 비용이 많이 들거나 거래량이 예측할 수 없는 새로운 서비스를 개발할 때 퍼블릭 클라우드로의 전환을 고려하고 있습니다. 신한은행은 AWS, LG CNS와 협업해 클라우드 인프라 구축과 애플리케이션 현대화를 위한 표준 시스템 구축에도 힘쓰고 있다. 은행 내 클라우드 환경 변화에 신속하게 대응하기 위한 인력 양성 프로그램을 통해 클라우드 인재 확보에 주력하고 있다.


본문

디지털 전환은 코로나19 팬데믹을 거치며 거스를 수 없는 시대적 흐름으로 자리잡았다. 그 중심에는 클라우드가 있다. 기술적인 완성도와 비즈니스 모델의 다변화로 클라우드 산업은 양적 질적 성장의 문턱에 서 있다. 아이뉴스24는 연중기획으로 국내외 클라우드 산업과 정책을 살펴보고 'K-클라우드 생태계'가 나아가야 할 방향을 모색해본다. [편집자주]

"은행에서 처음 시도한 음식 주문 플랫폼 '땡겨요'를 효율적으로 운영하기 위해 클라우드를 활용하고 있다"

한상훈 신한은행 ICT운영부 수석은 최근 열린 AWS 서밋 서울에서 아이뉴스24와 만나 "아마존웹서비스(AWS)와 같은 퍼블릭 클라우드를 통해 민첩하고 신속한 서비스 운영이 가능해졌다"며 '땡겨요'의 성공적인 시장 안착 비결을 이렇게 설명했다.

지난 2016년부터 클라우드 퍼스트 전략을 추진해 온 신한은행은 초기에 은행 내부적으로 프라이빗 클라우드를 구축·운영해오다 2019년부터 공용 망을 사용하는 퍼블릭 클라우드도 활용하고 있다. 프라이빗 클라우드와 함께 여러 퍼블릭 클라우드를 채택해 효율성을 극대화하고 있는 것이다.

한 수석은 "은행 전체 시스템 중 40%가 클라우드 상에서 운영되고 있고, 퍼블릭클라우드 전환 비율이 전체의 약 4%"라면서 "은행 자체의 클라우드 적합성 평가를 거쳐 클라우드 전환 유무 및 방식을 선택하고 있다"고 밝혔다.

고비용이 발생하거나 거래량 및 사용량을 예측하기 어려운 신규 서비스 개발의 경우 퍼블릭 클라우드 전환을 고려하고 있다는 게 그의 설명이다. 은행 배달 주문 서비스 '땡겨요'는 물론, 메타버스 플랫폼 '시나몬', 그룹의 AICC(인공지능 컨택센터) 사업 등이 대표적이다.

최근에는 AWS·LG CNS 등과 협력해 '뉴(New) 개발 플랫폼 사업'을 추진 중이다. 이는 클라우드 인프라 구축 및 애플리케이션 현대화(AM) 표준 체계 수립을 위해 진행됐다. AM은 클라우드 네이티브 관련 최신 기술을 활용해 애플리케이션을 구축하는 것을 의미한다.

한 수석은 "은행 내부 클라우드 환경 변화에 민첩하게 대처하기 위해 금융권 디지털전환(DX)의 기반이 되는 'AM 표준 체계'를 수립해야 했다"면서 "이를 통해 앱 개발 환경 표준화를 통해 다양한 서비스들이 클라우드 네이티브 환경에 구축되도록 할 수 있다"고 밝혔다.

신한은행은 자체 인력 교육 프로그램을 통해 클라우드 인재 확보에 집중하고 있다.

그는 "국내에 클라우드 네이티브 기술 개발 인력이 적을 뿐더러 금융 클라우드에 대한 지식을 갖추고 있기 어렵다"면서 "은행 내부적으로 금융 클라우드 관련 단계별 학습 가이드를 제공하는 등 자체 기술 인력을 양성하기 위해 노력하고 있다"고 전했다.


출처

https://n.news.naver.com/article/031/0000744797?sid=105 

 

[클라우드+] 신한은행 배달앱 '땡겨요' 성공 비결은 ◯◯◯◯

디지털 전환은 코로나19 팬데믹을 거치며 거스를 수 없는 시대적 흐름으로 자리잡았다. 그 중심에는 클라우드가 있다. 기술적인 완성도와 비즈니스 모델의 다변화로 클라우드 산업은 양적 질적

n.news.naver.com



헤드라인

알리바바 클라우드, 아발란체와 메타버스 플랫폼도 협력


요약

TechCrunch에 따르면 Alibaba Cloud와 Avalanche는 Alibaba 고객이 Avalanche 블록체인을 사용하여 메타버스 공간을 선보이고 관리할 수 있는 'Cloudverse'를 만들기 위해 협력했습니다. 협업에는 메타버스 통합 및 최적화를 지원하는 MUA DAO도 포함됩니다. Avalanche는 특정 요구 사항에 최적화할 수 있는 서브네트워크(서브넷)를 제공하여 Cloudverse용 ​​맞춤형 블록체인 솔루션을 개발하는 데 도움을 줍니다. 이 파트너십은 Alibaba Cloud가 2021년 12월 Avalanche 네트워크에 Nodes as a Service를 도입한 데 따른 것입니다.


본문

[디지털투데이 황치규 기자]알리바바 클라우드가 레이어1 블록체인 네트워크 아발란체와 메타버스 관련해 제휴를 맺었다. 

양사 협력은 알리바바 고객들이 아발란체 블록체인 기반으로 메타버스 공간을 선보이고 관리할 수 있는  '클라우드버스'(Cloudverse)를 제공하는데 초점이 맞춰져 있다고 테크크런치가 5일(현지시간) 보도했다.

알리바바 클라우드와 아발란체는 이와 관련해 MUA 다오(DAO)와도 협력한다. MUA 다오는 메타버스 통합 및 최적화를 지원하는 서비스 레이어라고 테크크런치는 전했다.

아발란체는 아발란체 기반으로 개발되는 노드들 집합인 서브넷웍스(subnetworks, 서브넷)을 제공한다. 서브넷은 아발란체에서 필요에 맞게 최적화될 수 있는 애플리케이션 특화 블록체인이다. 서브넷은 클라우드버스를 통해 맞춤형 블록체인 솔루션을 개발할 수 있도록 지원할 것이라고 테크크런치는 전했다.

알리바바 클라우드와 아발란체 협력은 이번이 처음은 아니다. 지난해 12월 알리바바 클라우드는 아발란체 네트워크에서 노드를 선보일 수 있도록 지원하는 서비스형 노드를 선보였다.


출처

http://www.digitaltoday.co.kr/news/articleView.html?idxno=475716 

 

알리바바 클라우드, 아발란체와 메타버스 플랫폼도 협력 - 디지털투데이 (DigitalToday)

[디지털투데이 황치규 기자]알리바바 클라우드가 레이어1 블록체인 네트워크 아발란체와 메타버스 관련해 제휴를 맺었다. 양사 협력은 알리바바 고객들이 아발란체 블록체인 기반으로 메타버

www.digitaltoday.co.kr



헤드라인

NHN클라우드, AI EXPO KOREA 2023 참가… 생활 속에 인공지능과 클라우드 솔루션 선보인다!

일상 속 편의 제공하는 AI얼굴인식, AI패션, OCR 등과 다년간 축적한 사업 역량, 노하우 기반 특화 클라우드 솔루션도 만나볼 수 있어


요약

백도민·김동훈 공동대표가 이끄는 NHN클라우드가 5월 10일부터 12일까지 서울 코엑스에서 열리는 제6회 국제인공지능전시회(AI EXPO KOREA 2023)에 참가해 AI 및 클라우드 솔루션을 선보인다. NHN 클라우드는 실생활에 접목된 AI 기술을 선보이고 고객과 공공기관에 실생활 AI 솔루션을 제공할 것입니다. 이번 전시에서는 AI EasyMaker, Notification, AppGuard 클라우드 솔루션과 함께 AI 얼굴인식, AI Fashion, OCR, TTS/STT AI 솔루션을 전시한다. NHN 클라우드는 AI 캐릭터 스튜디오, AI 상품 퀴즈 등 다양한 인터랙티브 콘텐츠도 제공할 예정이다. 한편, NHN의 자연어 처리 자회사인 NHN 다이퀘스트도 같은 부스에서 자연어 솔루션을 전시한다.


본문

엔에이치엔 클라우드(NHN Cloud, 공동대표 백도민·김동훈. 이하, NHN클라우드)는 오는 10일부터 12일까지 사흘간 서울 삼성동 COEX에서 아시아 최대로 개최되는 '제6회 국제인공지능대전(AI EXPO KOREA 2023)'에 참가해 자사 AI 및 클라우드 솔루션과 실생활 속에 녹아든 자사의 인공지능 기술들을 선보인다.

특히, NHN클라우드는 실생활 AI 솔루션들을 다수 고객사 및 공공기관에 공급하며 일상에 편의를 제공해 나가고 있다. 지난 4월에는 NHN클라우드가 자사 STT 기술을 활용, 청각장애인 학습권 보장을 위해 2,000여개의 교육 영상 음성을 문자로 변환해 자막으로 반영하는 사회공헌활동을 전개했으며 그 공로를 인정받아 해당 사업을 추진한 한국교육학술정보원(KERIS)으로부터 감사장인 ‘으뜸동반자상’을 수여하기도 했다.

이번 전시에서는 ▷클라우드 솔루션으로는 NHN이 다년간 다채로운 사업을 전개하며 축적한 역량과 노하우가 녹아 있는 특화 서비스들이 전시된다. ▲AI 솔루션을 손쉽게 개발할 수 있도록 돕는 ‘AI EasyMaker’ ▲고객사가 보유한 회원들을 대상으로 Push, SMS, 이메일, 카카오톡 비즈 메시지 등 다양한 방식으로 메시지를 전달할 수 있는 ‘Notification’ ▲안드로이드 및 iOS 모바일 앱의 부정행위 탐지와 보안위협 대응을 제공하는 모바일 앱 보호 서비스 ‘NHN AppGuard’를 만나볼 수 있다.

▷AI솔루션으로 ▲얼굴 감지 및 분석, 비교를 포함한 얼굴 인식 관련 다수 서비스를 제공해 다양한 상황에서 활용가능한 ‘AI Face Recognition’ ▲다양한 카테고리의 상품 데이터를 기반으로 학습해 이미지 내 상품 검색은 물론, 유사 상품 추천 등 패션 분야 특화 서비스를 제공하는 ‘AI Fashion’ ▲신용카드, 사업자등록증, 차량번호판 등 다양한 문서 및 이미지의 문자 영역을 인식하고 영역별 문자를 추출하는 ‘OCR(Optical Character Recognition)’ ▲입력된 텍스트를 인식하여 자연스러운 음성으로 합성하거나 음성을 텍스트로 변환하는 ‘TTS/STT(Text to Speech/Speech to Text)’ 등을 출품할 예정이다.

또한 NHN 클라우드의 독자적인 AI 기술로 생성한 캐릭터 사진을 체험해 볼 수 있는 ‘AI캐릭터 스튜디오’, 재미있는 AI 기술 이야기로 구성된 AI상품 퀴즈/스탬프 미션을 통해 기념품을 획득할 수 있는 이벤트 등 다채롭고 흥미로운 콘텐츠도 마련될 예정이다.

NHN클라우드 권경희 이사는 “일상을 윤택하고 편리하게 해주는 AI 솔루션들과 고객의 비즈니스를 유연하고 안전하게 전환해주는 클라우드 솔루션들을 이번 AI EXPO KOREA 2023에서 선보이게 되었다”며 “이번 행사에 참여하는 모든 기업 관계자들이 각종 사업 현장에서 실효성이 검증된 NHN클라우드의 솔루션들을 체험하며 비즈니스 혁신을 이뤄 나가게 되는 소중한 기회를 얻어갈 수 있기를 바란다”고 밝혔다.

한편, NHN의 자연어 처리 전문 자회사 ‘NHN다이퀘스트’도 NHN클라우드와 같은 부스에서 자연어 관련 솔루션을 출품한다. 인공지능 챗봇 솔루션 ‘인포채터(Infochatter)’, 빅테이터 통합 분석 플랫폼 ‘디플랫폼(Dplatform)’ 외 4가지 솔루션을 부스에서 체험할 수 있다.


출처

https://www.aitimes.kr/news/articleView.html?idxno=27945 

 

NHN클라우드, AI EXPO KOREA 2023 참가… 생활 속에 인공지능과 클라우드 솔루션 선보인다! - 인공지능

엔에이치엔 클라우드(NHN Cloud, 공동대표 백도민·김동훈. 이하, NHN클라우드)는 오는 10일부터 12일까지 사흘간 서울 삼성동 COEX에서 아시아 최대로 개최되는 \'제6회 국제인공지능대전(AI EXPO KOREA 20

www.aitimes.kr



헤드라인

일본, 법적 효력 있는 디지털 유언장 제도 만든다

니혼게이자이 "PC나 스마트폰으로 작성해 클라우드에 보관"


요약

니혼게이자이신문이 ​​6일 보도한 바에 따르면 일본 정부는 법적 구속력이 있는 디지털 유언장을 작성·보관할 수 있는 시스템을 구축할 계획이다. 일본의 현행 민법은 유언을 본인이 종이에 작성한 유언, 공증인에게 위탁한 공증 유언, 공증인이 보관하는 비밀문서 유언 등 3가지 유형을 인정하고 있다. 제안된 디지털 유언장 시스템은 사람들이 PC나 스마트폰을 사용하여 클라우드에서 유언장을 작성하고 저장할 수 있도록 합니다. 종이 유언장과 달리 분실 위험이 없으며 블록체인 기술은 조작을 방지하는 데 도움이 될 수 있습니다. 새로운 시스템의 목표는 사람들이 유언장을 쉽게 만들고 디지털 시대에 상속이 보다 원활하게 수행될 수 있도록 하는 것입니다.


본문

(도쿄=연합뉴스) 김호준 특파원 = 일본 정부는 법적 효력이 있는 디지털 유언장을 작성해 보관할 수 있는 제도를 만들 계획이라고 니혼게이자이신문이 6일 보도했다.

보도에 따르면 일본 법무성은 올해 안에 디지털 유언장 제도를 검토하는 전문가 회의를 출범시켜 내년 3월께 새로운 제도의 방향을 제안하게 할 방침이다.

일본의 현행 민법 규정을 보면 유언장은 ▲ 본인이 종이에 쓴 자필증서유언 ▲ 공증인에게 작성을 위탁한 공증증서 유언 ▲ 봉인한 유언서를 공증 사무소가 보관하는 비밀증서유언 등 세 종류가 있다.

새 제도로는 PC나 스마트폰으로 디지털 유언장을 작성해 클라우드 등에 보관하는 방안이 거론된다.

현재 자필 유언은 본인이 펜을 사용해 종이에 본문과 작성일 등을 적고 서명, 날인을 하지 않으면 법적 효력이 없다.

정부가 보관하는 자필 유언은 용지의 크기와 여백, 페이지 번호를 매기는 방법까지 세세하게 규정돼 있어 본인이 작성하기는 어렵고 변호사의 도움을 받는 경우가 많다.

인터넷상에서 유언장 작성이 가능해지면 정해진 양식에 따라 입력하면 되기 때문에 유언 제도를 잘 모르는 사람도 직접 만들 수 있게 된다.

종이 유언장과 달리 분실 위험이 없고 블록체인 기술을 이용하면 조작 위험도 방지할 수 있다.

니혼게이자이는 "디지털 사회에서 이용하기 쉬운 유언 제도를 도입해 원활한 상속이 이뤄지게 하려는 것"이라며 디지털 유언장 제도 추진 배경을 설명했다.


출처

https://n.news.naver.com/article/001/0013924374?sid=104 

 

일본, 법적 효력 있는 디지털 유언장 제도 만든다

니혼게이자이 "PC나 스마트폰으로 작성해 클라우드에 보관" 김호준 특파원 = 일본 정부는 법적 효력이 있는 디지털 유언장을 작성해 보관할 수 있는 제도를 만들 계획이라고 니혼게이자이신문이

n.news.naver.com



헤드라인

“검색으로 잘 먹고 살았는데”… 챗GPT 열풍에 위기감 커진 구글·네이버

MS 빙, 챗GPT 탑재 후 하루 이용자 1억명
네이버 검색 점유율 60% 아래로
다음, 카카오서 분리 결정
”젊은층 40%, 식사장소 찾을 때 구글 대신 틱톡·인스타 활용”


요약

네이버, 구글 등 빅테크 기업들은 초거대 인공지능(AI) 기술의 등장으로 변화하는 검색엔진 게임에 적응해야 한다는 압박을 받고 있다. 네이버는 자체 초거대 AI '하이퍼 클로바'를 선보였으며, 하이퍼 클로바 후속 버전 기반의 차세대 검색 서비스인 '서치 GPT'를 오는 7월 공개할 예정이다. 구글도 람다 기반의 초대형 AI 챗봇 '바드'를 내놨지만 마이크로소프트가 오픈AI에 대규모 투자를 하고 자사 검색엔진 '빙'에 챗GPT를 적용한 상황이다. 전문가들은 초거대 AI 기술이 앞으로 검색 엔진의 판도를 바꿀 것이라고 믿고 있습니다. 삼성전자도 기존 구글 검색엔진을 빙으로 교체하는 방안을 검토해 구글에 비상을 걸었다. 나아가 MZ세대는 틱톡, 인스타그램, 페이스북, 유튜브 등 플랫폼에 의존해 검색 방식을 바꾸고 있다.


본문

“생성형 AI가 완전히 새로운 방식으로 정보를 다룰 수 있게 해줄 것입니다.”(프라바카르 라그하반 구글 검색엔진 부사장)

“기술의 진보가 이렇게 빠를지 몰랐습니다. 초거대 인공지능(AI)을 서비스에 적용하지 않으면 도태될 것이라는 생각에 전사적으로 역량을 집중하고 있습니다.”(네이버 관계자)

오픈AI의 AI 챗봇 ‘챗GPT’ 열풍에 국내외 빅테크 기업들이 “변화하지 않으면 뒤바뀌는 판에서 생존할 수 없다”는 위기감을 느끼고 있다. 국내 검색시장 1위인 네이버는 물론이고 글로벌 검색엔진 절대 강자인 구글이 다급해진 것이다.

네이버는 사내기업(CIC) 클로바에서 개발하던 초거대 AI ‘하이퍼클로바’를 2021년 5월 처음 공개했다. 올해 1월에는 하이퍼클로버 CIC를 네이버클라우드로 합병시키며 초거대 AI 사업에 속도를 내고 있다. 오는 7월에는 하이퍼클로바의 후속 버전인 ‘하이퍼클로바X’를 기반으로 한 차세대 검색 서비스 ‘서치GPT’(가칭)를 공개할 예정이다. 하이퍼클로바X는 챗GPT 대비 한글 데이터를 6500배 더 많이 학습한 대규모 AI 모델이다. 한국에 특화된 서비스로 국내 시장을 사수하겠다는 포석이다.

구글은 검색엔진 후발주자인 마이크로소프트(MS)가 지난 2월 오픈AI에 100억달러(13조원) 상당의 대규모 투자를 하고, 자사 검색엔진 ‘빙’에 챗GPT를 적용하자 바짝 긴장하고 있다. 구글은 초거대 AI ‘람다’ 기반 AI 챗봇 ‘바드’를 내놓고 이를 검색엔진에 탑재했지만 상황은 녹록치 않다. 미국 경제전문매체 CNBC는 지난달 “챗GPT에 투자한 MS는 AI 분야의 주도권을 구글로부터 빼앗아왔다”고 전했다.

 

초대형AI로 판도 뒤집어지나…MS, 구글반격


전문가들은 초거대 AI 기술이 향후 검색엔진의 판도를 뒤바꿀 수 있을 것이라 본다.

실제 MS의 빙은 AI 검색 기술을 도입하면서 이용자가 급속히 늘었다. 사티아 나델라 MS 최고경영자(CEO)는 지난달 25일(현지시각) “챗GPT 탑재 이후 빙 하루 이용자가 1억명에 달한다”고 말했다. 이 같은 성과는 MS가 빙에 AI 검색 기술을 도입한 지 한 달 만의 일이다. MS는 “여전히 빙 검색엔진 점유율이 낮지만, 그동안 빙을 사용해본 적 없는 이용자를 끌어들인 것에 의미가 있다”고 말했다.

삼성전자가 갤럭시 스마트폰에 기본 탑재되는 검색엔진을 기존 구글 대신 빙으로 대체하는 것을 고려하면서 구글은 비상이 걸렸다.

네이버 역시 점차 국내 검색 시장의 장악력이 떨어지고 있다. 웹사이트 분석 페이지 인터넷트렌드에 따르면 현재 네이버의 검색 점유율은 59.46%다. 여전히 1위이지만, 2016년 점유율이 80%에 육박했던 것과 비교하면 대조적이다. 네이버의 검색 점유율은 2020년 50%대로 내려앉은 후 줄곧 50~60%대를 유지하고 있다.

카카오와 합병 이후 시너지를 보여주지 못한 다음은 지난 4일 사내독립기업(CIC)으로 분리를 결정했다. 카카오의 사업부분으로 있을 경우 의사결정이 느리다는 판단에서다. 다음은 지난해 검색 점유율이 4%로 쪼그라들었다.

여기다 MZ 세대를 중심으로 검색방식이 바뀔 것이라는 전망도 이어지고 있다. MZ세대들은 구글, 네이버에만 의존하지 않고 틱톡, 인스타그램, 페이스북, 유튜브 등을 통해 검색한다. 프라바카르 라그하반 구글 검색엔진 부사장은 지난해 7월 “젊은층의 40%가 식사 장소를 찾을 때 구글 대신 틱톡이나 인스타그램을 활용하는 것으로 조사됐다”고 말했다.


출처

https://n.news.naver.com/article/366/0000899358?sid=105 

 

“검색으로 잘 먹고 살았는데”… 챗GPT 열풍에 위기감 커진 구글·네이버

MS 빙, 챗GPT 탑재 후 하루 이용자 1억명 네이버 검색 점유율 60% 아래로 다음, 카카오서 분리 결정 ”젊은층 40%, 식사장소 찾을 때 구글 대신 틱톡·인스타 활용” “생성형 AI가 완전히 새로운 방식

n.news.naver.com



헤드라인

미국이 때려도 버티는 中 화웨이…내수·보조금·자체 개발이 비결


요약

파이낸셜 타임즈의 최근 보도에 따르면 중국 IT 대기업 화웨이는 미국 정부의 경제 제재와 매출 및 시장 점유율 하락에도 불구하고 내수 중심 경영과 자체 개발, 중국 정부의 막대한 보조금 지원으로 강세를 보이고 있습니다. 화웨이는 미국의 경제 제재로 업데이트가 금지되기 전까지 사용하던 미국산 오라클 ERP 시스템을 대체하기 위해 자체 ERP 시스템을 개발했습니다. 중국 정부는 지난해 화웨이에 65억 5,000만 위안(약 1조 2,500억 원)의 보조금을 지급했으며, 화웨이는 매출의 4분의 1을 R&D에 투자했습니다. 지난해 기준 순이익이 356억 위안(6조 8천억 원)으로 감소했지만 화웨이의 창업자이자 순환 회장인 멍완저우(孟晩舟)는 스토리지와 클라우드 기술에 대한 투자를 계속할 것이라고 밝히며 "미국에 맞서 싸우겠다"는 의지를 드러냈습니다.


본문

2019년 중국의 스파이 활동 연루 의혹과 함께 미국 정부로부터 경제 제재를 받고 있는 중국의 거대 IT기업 화웨이가 내수 위주의 경영과 자체 개발, 중국 정부의 막대한 보조금에 힘입어 여전히 건재함을 보여주고 있다고 영국 파이낸셜타임스(FT)가 최근 보도했다.

FT는 최근 화웨이가 자체 개발해 기존의 미국산 ERP(전사적자원관리) 시스템을 대체한 것을 사례로 들었다. 지난달 화웨이 광둥성 둥관 R&D 단지에서는 직원들이 자체 개발한 ERP 개통을 축하하는 행사를 열었다. 그동안 화웨이는 미국산 오라클 ERP 시스템을 사용했는데, 3년 전부터 미국의 경제 제재로 인해 ERP 업데이트가 안 되면서 자체 개발에 나선 것이다. 타오징원 화웨이 사장은 “오늘 우리는 (미국의) 제재를 돌파했다고 자랑스럽게 선포한다”며 “우리는 살아남았다”고 강조했다.

화웨이의 지난 4년간 처절한 생존 투쟁을 벌여야 했다. 2019년 경제 제재 이후 화웨이는 미국 정부 허가 없이 미국 공급업체로부터 제품을 공급받거나 미국 기술을 사용하는 것을 금지당했다. 회사의 매출과 순이익, 시장점유율은 곤두박질 쳤다. 국내에서도 5G(5세대 이동통신) 설비에 화웨이 장비를 쓰는지 여부를 두고 논란이 일었다. 이후 2021년 화웨이는 매출이 전년 대비 3분의 1로 줄었고, 중저가 스마트폰 브랜드 ‘아너’ 부문을 매각했다.

하지만 화웨이는 이후 중국 정부의 막대한 지원금을 바탕으로 R&D와 내수 진작에 집중 했고, 그 결과 상당 부분 서방 국가의 장비와 서비스를 자국산으로 대체하는 효과가 있었다는 것이 FT의 분석이다. 중국 정부는 지난해 화웨이에 65억5000만 위안(약 1조2500억원)을 화웨이에 보조금으로 지급했다. 전년 대비 2배에 달하는 돈이다. 화웨이는 또 지난해 매출액의 4분의1을 R&D에 투자했다고 발표했다.

그 결과 화웨이는 해외 장비를 국산화하는데 상당한 진전을 얻었다. 런정페이 화웨이 창업자는 “미국 경제제재 이후 1만3000개 이상의 부품과 4000개 이상의 회로 기판을 재설계해 국산화했다”고 지난 2월 밝혔다. 네덜란드 ASML이 독점하고 있는 반도체 첨단기술 ‘리소그래피’에도 화웨이는 도전장을 내고 있다.

아직 화웨이는 작년 기준 순이익 356억 위안(6조8000억원)으로 2019년 627억 위안(12조원)에 비해 절반 수준에 그친다. 하지만 멍완저우 화웨이 순환회장은 “스토리지와 클라우드 같은 기술에 꾸준히 투자하겠다”면서 ‘대미항전’의 의지를 불태웠다고 FT는 전했다.

한편, 국내에서도 지난달 국가정보원의 화웨이 장비 조사가 진행된 것으로 알려졌다. 뉴시스에 따르면, 국정원은 당시 “우리 정부 기관ㆍIT 보안업체의 국제사회 제재 위반 연루로 인한 피해 방지 차원에서 공공기관을 대상으로 화웨이를 포함한 국제사회 제재 IT제품 도입현황을 파악했다”고 밝혔다. 이를 두고 미국 주도의 화웨이 제재로 인한 국내 기업의 피해를 막기 위한 취지라는 분석이 나왔다.


출처

https://n.news.naver.com/article/023/0003762089?sid=101 

 

미국이 때려도 버티는 中 화웨이…내수·보조금·자체 개발이 비결

2019년 중국의 스파이 활동 연루 의혹과 함께 미국 정부로부터 경제 제재를 받고 있는 중국의 거대 IT기업 화웨이가 내수 위주의 경영과 자체 개발, 중국 정부의 막대한 보조금에 힘입어 여전히

n.news.naver.com


반응형
반응형

오늘은 MySQL을 다운로드 받고 이전에 제작한 html과 DB를 연결해 로그인 기능을 구현하려 했습니다. 해당 내용을 구현하기 위해 해당 페이지를 참고했으나 제작하는 과정에서 오류가 많이 나와 오늘은 미완성인 채로 아쉽게 마무리 되었습니다. 이전에 중구난방으로 html과 css를 제작했었으나 이번에는 각각 폴더를 지정해 몰아 넣어 정리했습니다. 하지만, 저는 오늘 건강관계상 같이 토론은 못하고 내용을 전달받고 이 코드가 무슨뜻인지 주석을 달아주는 것 밖에 못했습니다. DB랑 연결해서 실험을 해봐야하는데, 오늘은 이렇게 가볍게 마치고 이번 주말에 더 공부해볼 생각입니다.

 

다음은 코드와 무슨 뜻인지 정리되어있으니 참고할 수 있을 것으로 생각됩니다. 참고로 html의 주석은 <!--  -->, 파이썬의 주석은 #, sql의 주석은 -- 입니다. 이 때 html의 주석의 내용은 <!--    --> 이 빨간 부분에 작성하게 됩니다.

 

1. main.html : 메인 페이지

<!DOCTYPE html> <!-- HTML5 문서 유형 선언 -->
<html> <!-- HTML 문서 시작 -->
<head> <!-- 문서의 메타데이터를 포함하는 요소 -->
    <title>My Ebook Page</title> <!-- 문서 제목 -->
    <link rel="stylesheet" type="text/css" href="{{ url_for('static', filename='main.css')}}"> <!-- 외부 CSS 파일 연결 -->
</head>
<body> <!-- 문서의 본문을 포함하는 요소 -->
    <header> <!-- 문서의 머리말을 나타내는 요소 -->
        <div class="logo"> <!-- 로고 이미지를 담는 div 요소 -->
            <img src="{{ url_for('static', filename='logo.png') }}" alt="My Ebook Logo"> <!-- 로고 이미지 -->
        </div>
        <div class="search"> <!-- 검색창을 담는 div 요소 -->
            <input type="text" placeholder="Search..."> <!-- 검색창 input 요소 -->
        </div>
        <div class="user"> <!-- 로그인, 마이 페이지 링크를 담는 div 요소 -->
            <a href="/login">로그인</a> | <!-- 로그인 링크 -->
            <a href="/mypage">마이 페이지</a> <!-- 마이 페이지 링크 -->
        </div>
    </header>
    <nav> <!-- 문서의 내비게이션을 담는 요소 -->
        <ul> <!-- 내비게이션 목록을 담는 ul 요소 -->
            <li><a href="#">일반</a></li> <!-- 일반 카테고리 링크 -->
            <li><a href="#">로맨스</a></li> <!-- 로맨스 카테고리 링크 -->
            <li><a href="#">판타지</a></li> <!-- 판타지 카테고리 링크 -->
            <li><a href="#">미스테리</a></li> <!-- 미스테리 카테고리 링크 -->
            <li><a href="#">추리</a></li> <!-- 추리 카테고리 링크 -->
        </ul>
    </nav>
    <section>
        <h2>추천 도서</h2>
        <div class="book-list">
            <!-- Recommended book 1 -->
            <div class="book">
                <img src="{{ url_for('static', filename='book1.jpg') }}" alt="Book 1">
                <h3>세이노의 가르침</h3>
                <p>000년부터 발표된 그의 주옥같은 글들. 독자들이 자발적으로 만든 제본서는 물론, 전자책과 앱까지 나왔던 《세이노의 가르침》이 드디어 전국 서점에서 독자들을 마주한다. </p>
                <button>Read Now</button>
            </div>
            <!-- Recommended book 2 -->
            <div class="book">
                <img src="book2.jpg" alt="Book 2">
                <h3>NCS 통합 기본서</h3>
                <p>기획재정부 시행 ‘공공기관 채용박람회’ NCS 초청강사 집필! 공사 공단 및 금융권 필기 전형 대비</p>
                <button>Read Now</button>
            </div>
            <!-- Recommended book 3 -->
            <div class="book">
                <img src="book3.jpg" alt="Book 3">
                <h3>대한민국 청약지도</h3>
                <p>추첨제 부활! 사상 최대 특별공급 확대! 중도금 대출 완화! 당신이 알던 ‘청약’의 모든 것이 달라졌다</p>
                <button>Read Now</button>
            </div>
        </div>
        <h2>신상 도서</h2>
        <div class="book-list">
            <!-- New book 1 -->
            <div class="book">
                <img src=https://books.google.com/books/content?id=C2hMEAAAQBAJ&printsec=frontcover&img=1&zoom=1&edge=curl&source=gbs_api alt="Book 4">
                <h3>내일을 바꾸는 인생 정보</h3>
                <p>평온한 밤을 위한 인생의 클래식, 잠 못 이루는 오늘, 당신이 묻고 고전이 답하다! </p>
                <button>Read Now</button>
            </div>
            <!-- New book 2 -->
            <div class="book">
                <img src="book5.jpg" alt="Book 5">
                <h3>면접바이블</h3>
                <p>독보적 취업 유튜버 ‘면접왕 이형’의 베스트셀러 ‘면접 바이블’이 개정판으로 돌아왔다!</p>
                <button>Read Now</button>
            </div>
            <!-- New book 3 -->
            <div class="book">
                <img src="book6.jpg" alt="Book 6">
                <h3>장하준의 경제 레시피</h3>
                <p>“자유 시장의 자유에 맡겨 두면 경제가 저절로 발전할까?” “사람들이 가난한 건 게으르기 때문일까?”</p>
                <button>Read Now</button>
            </div>
        </div>
    </section>
    <footer>
        <p>Copyright &copy;
          <script>
            document.write(new Date().getFullYear())
          </script> Etevers e-book. All Rights Reserved.</p>
    </footer>
</body>
</html>

 

2. mypage.html : 마이페이지

<!DOCTYPE html> <!-- HTML5 문서 유형 선언 -->
<html> <!-- HTML 문서 시작 -->
<head> <!-- head 태그 시작 -->
  <title>My Ebook Page</title> <!-- 문서 제목 -->
  <meta name="viewport" content="width=device-width, initial-scale=1.0"> <!-- 반응형 웹을 위한 뷰포트 설정 -->
  <title>My Account</title> <!-- 탭 제목 -->
  <link href="https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;700&display=swap" rel="stylesheet"> <!-- 구글 폰트 링크 -->
  <link rel="stylesheet" href="{{ url_for('static', filename='mypage.css')}}"> <!-- CSS 파일 링크 -->
</head> <!-- head 태그 종료 -->
<body>
  <header> <!-- 헤더 영역 -->
    <div class="logo"> <!-- 로고 이미지 -->
      <img src="{{ url_for('static', filename='logo.png') }}" alt="My Ebook Logo">
    </div>
    <div class="search"> <!-- 검색창 -->
      <input type="text" placeholder="Search...">
    </div>
    <div class="user"> <!-- 사용자 정보 -->
      <a href="#">로그아웃</a> | <a href="#">마이 페이지</a>
    </div>
  </header>
  <nav> <!-- 네비게이션 바 -->
    <ul>
      <li><a href="#">일반</a></li>
      <li><a href="#">로맨스</a></li>
      <li><a href="#">판타지</a></li>
      <li><a href="#">미스테리</a></li>
      <li><a href="#">추리</a></li>
    </ul>
  </nav>
  <main> <!-- 메인 컨텐츠 영역 -->
    <h2>나의 정보</h2> <!-- 제목 -->
    <dl> <!-- 설명 리스트 -->
      <dt>이름</dt> <!-- 설명 제목 -->
      <dd>이주성</dd> <!-- 설명 내용 -->
      <dt>이메일</dt>
      <dd>wntjd@example.com</dd>
      <dt>전화번호</dt>
      <dd>010-1234-5678</dd>
      <dt>주소</dt>
      <dd>서울시 강남구 역삼동 123-456</dd>
    </dl>
    <h2>최근 주문 내역</h2> <!-- 제목 -->
    <table> <!-- 테이블 -->
      <thead> <!-- 테이블 헤더 -->
        <tr>
          <th>주문 번호</th>
          <th>제목</th>
          <th>가격</th>
          <th>구매일자</th>
        </tr>
      </thead>
      <tbody> <!-- 테이블 바디 -->
        <tr>
          <td>12345</td>
          <td>해리포터와 마법사의 돌</td>
          <td>12,000원</td>
          <td>2022-04-18</td>
        </tr>
        <tr>
          <td>12344</td>
          <td>물고기의 언어</td>
          <td>9,000원</td>
          <td>2022-04-17</td>
        </tr>
      </tbody>
    </table>
  </main>
  <footer> <!-- 푸터 영역 -->
    <p> <!-- 문장 -->
      Copyright &copy;
      <script>
        document.write(new Date().getFullYear())  <!-- 현재 연도 자동으로 출력 -->
      </script> Etevers e-book. All Rights Reserved. <!-- 출판사 정보 -->
    </p>
  </footer>
</body>

 

3. login.html : 로그인 페이지

<!DOCTYPE html> <!-- HTML5 문서 유형 선언 -->
<html lang="en"> <!-- 문서 언어 설정 -->
<head> <!-- head 태그 시작 -->
    <meta charset="UTF-8"> <!-- 문자 인코딩 설정 -->
    <meta name="viewport" content="width=device-width, initial-scale=1.0"> <!-- 반응형 웹 설정 -->
    <title>Document</title> <!-- 문서 제목 -->
    <link href="https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;700&display=swap" rel="stylesheet">
    <!-- 구글 폰트 링크 -->
    <script src="https://kit.fontawesome.com/53a8c415f1.js" crossorigin="anonymous"></script>
    <!-- Font Awesome 아이콘 링크 -->
    <link rel="stylesheet" href="{{ url_for('static', filename='login.css')}}"> <!-- CSS 파일 링크 -->
</head> <!-- head 태그 종료 -->
<body>
    <div class="wrap">
        <div class="login">
            <h2>Log-in</h2>
            <div class="loginaction">
                <!-- 로그인 폼 -->
                <form action="{{ url_for('login')}}" method="post" autocomplete="off">
                    <!-- 메시지 출력 -->
                    <div class="msg">{{ msg }}</div>
                    <!-- 아이디 입력 -->
                    <div class="login_id">
                        <h4>ID</h4>
                        <input type="text" name="" id="" placeholder="ID">
                    </div>
                    <!-- 비밀번호 입력 -->
                    <div class="login_pw">
                        <h4>Password</h4>
                        <input type="password" name="" id="" placeholder="Password">
                    </div>
                    <!-- 기타 옵션 -->
                    <div class="login_etc">
                        <!-- 아이디 저장 체크박스 -->
                        <div class="checkbox">
                            <input type="checkbox" name="" id=""> 아이디 저장
                        </div>
                        <!-- 비밀번호 찾기 링크 -->
                        <div class="forgot_pw">
                            <a href="">비밀번호 찾기</a>
                        </div>
                    </div>
                    <!-- 로그인 버튼 -->
                    <div class="submit">
                        <input type="submit" value="login">
                    </div>
                </form>
            </div>
            <!-- 회원가입 버튼 -->
            <div class="submit">
                <a href="/signup">
                    <input type="submit" value="Sign Up">
                </a>
            </div>
        </div>
    </div>
</body>
</html>

 

4. sginup.html : 회원가입 페이지

<!DOCTYPE html> <!-- HTML5 문서 유형 선언 -->
<html lang="en"> <!-- 문서 언어 설정 -->
<head> <!-- head 태그 시작 -->
    <meta charset="UTF-8"> <!-- 문자 인코딩 설정 -->
    <meta name="viewport" content="width=device-width, initial-scale=1.0"> <!-- 반응형 웹 설정 -->
    <title>Document</title> <!-- 문서 제목 -->
    <link href="https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;700&display=swap" rel="stylesheet">
    <!-- 구글 폰트 링크 -->
    <script src="https://kit.fontawesome.com/53a8c415f1.js" crossorigin="anonymous"></script>
    <!-- Font Awesome 아이콘 링크 -->
    <link rel="stylesheet" href="{{ url_for('static', filename='login.css')}}"> <!-- CSS 파일 링크 -->
</head> <!-- head 태그 종료 -->
<body>
    <div class="wrap">
        <div class="login">
            <h2>Log-in</h2>
            <div class="loginaction">
                <!-- 로그인 폼 -->
                <form action="{{ url_for('login')}}" method="post" autocomplete="off">
                    <!-- 메시지 출력 -->
                    <div class="msg">{{ msg }}</div>
                    <!-- 아이디 입력 -->
                    <div class="login_id">
                        <h4>ID</h4>
                        <input type="text" name="" id="" placeholder="ID">
                    </div>
                    <!-- 비밀번호 입력 -->
                    <div class="login_pw">
                        <h4>Password</h4>
                        <input type="password" name="" id="" placeholder="Password">
                    </div>
                    <!-- 기타 옵션 -->
                    <div class="login_etc">
                        <!-- 아이디 저장 체크박스 -->
                        <div class="checkbox">
                            <input type="checkbox" name="" id=""> 아이디 저장
                        </div>
                        <!-- 비밀번호 찾기 링크 -->
                        <div class="forgot_pw">
                            <a href="">비밀번호 찾기</a>
                        </div>
                    </div>
                    <!-- 로그인 버튼 -->
                    <div class="submit">
                        <input type="submit" value="login">
                    </div>
                </form>
            </div>
            <!-- 회원가입 버튼 -->
            <div class="submit">
                <a href="/signup">
                    <input type="submit" value="Sign Up">
                </a>
            </div>
        </div>
    </div>
</body>
</html>

 

5. app.py : flask를 DB와 파이썬 연결

from flask import Flask, render_template, request, redirect, url_for, session # Flask, render_template, request, redirect, url_for, session 모듈 import
from flask_mysqldb import MySQL  # Flask MySQL 모듈 import
import MySQLdb.cursors  # MySQLdb.cursors 모듈 import
import re  # re 모듈 import
app = Flask(__name__, static_folder='static') # Flask 객체 생성
app.secret_key = 'your secret key' # 세션 보안을 위한 secret key 설정
app.config['MYSQL_HOST'] = 'localhost' # MySQL 호스트 설정
app.config['MYSQL_USER'] = 'root' # MySQL 유저 설정
app.config['MYSQL_PASSWORD'] = '1234' # MySQL 비밀번호 설정
app.config['MYSQL_DB'] = 'ebook' # MySQL 데이터베이스 설정
mysql = MySQL(app) # MySQL 객체 생성
# 홈페이지
@app.route('/')  # '/' 경로로 들어왔을 때 실행되는 함수
def home():
    return render_template('main.html')  # 'main.html' 파일을 렌더링하여 반환
# 로그인 페이지
@app.route('/login', methods=['GET', 'POST'])
def login():
    msg = ''
    if request.method == 'POST' and 'account' in request.form and 'password' in request.form:  # 만약 요청 방식이 POST이고, 폼 데이터에 'account'와 'password'가 모두 있다면
        account = request.form['account']  # POST 요청에서 account 값을 가져옴
        password = request.form['password']  # POST 요청에서 password 값을 가져옴
        cursor = mysql.connection.cursor(
            MySQLdb.cursors.DictCursor)  # MySQLdb 모듈을 사용하여 커서 생성
        cursor.execute(
            'SELECT * FROM user WHERE account = % s \
            AND password = % s', (account, password, ))  # SQL 쿼리 실행
        user = cursor.fetchone()  # 쿼리 결과를 가져옴
        if user:  # 쿼리 결과가 있으면
            session['loggedin'] = True  # 로그인 상태를 True로 변경
            session['account'] = user['account']  # 세션에 account 값을 저장
            session['password'] = user['password']  # 세션에 password 값을 저장
            msg = 'Logged in successfully !'  # 로그인 성공 메시지
            return render_template('main.html', msg=msg) # main.html 페이지를 렌더링하며 msg 값을 전달
        else:  # 쿼리 결과가 없으면
            msg = 'Incorrect username / password !'  # 로그인 실패 메시지
    return render_template('login.html', msg=msg) # login.html 페이지를 렌더링하며 msg 값을 전달

# 로그아웃
@app.route('/logout')
def logout():
    session.pop('loggedin', None)  # 'loggedin' 세션 삭제
    session.pop('account', None)  # 'account' 세션 삭제
    session.pop('password', None)  # 'password' 세션 삭제
    return redirect(url_for('login'))  # login 페이지로 리다이렉트
# 회원가입 페이지
@app.route('/signup', methods=['GET', 'POST'])
def signup():
    msg = ''
    # 다음 코드는 POST 요청이 들어왔을 때, 모든 필드가 채워졌는지 확인하고, 채워졌다면 해당 값을 변수에 저장한다.
    if request.method == 'POST' \
            and 'account' in request.form \
            and 'password' in request.form \
            and 'username' in request.form \
            and 'email' in request.form \
            and 'gender' in request.form \
            and 'birth' in request.form \
            and 'phonenumber' in request.form:
        account = request.form['account']
        password = request.form['password']
        username = request.form['username']
        email = request.form['email']
        gender = request.form['gender']
        birth = request.form['birth']
        phonenumber = request.form['phonenumber']
        # 다음 코드는 MySQL 데이터베이스에 연결하고, 입력한 계정이 이미 존재하는지 확인한다.
        cursor = mysql.connection.cursor(MySQLdb.cursors.DictCursor)
        cursor.execute(
            'SELECT * FROM user WHERE account = % s', (account, ))
        user = cursor.fetchone()
        # 다음 코드는 이미 존재하는 계정이라면 에러 메시지를 출력한다.
        if user:
            msg = '이미 존재하는 계정입니다 !'
        # 다음 코드는 이메일 형식이 올바르지 않다면 에러 메시지를 출력한다.
        elif not re.match(r'[^@]+@[^@]+\.[^@]+', email):
            msg = 'Email 형식에 맞지 않습니다 !'
        # 다음 코드는 이름이 올바른 형식이 아니라면 에러 메시지를 출력한다.
        elif not re.match(r'[A-Za-z0-9]+', username):
            msg = 'name must contain only characters and numbers !'
        # 다음 코드는 모든 조건을 만족한다면, 데이터베이스에 새로운 사용자 정보를 추가한다.
        else:
            cursor.execute('INSERT INTO user VALUES \
                (% s, % s, % s, % s, % s, % s, % s)',
                           (account, password, username, email, gender, birth, phonenumber))
            mysql.connection.commit()
            msg = '가입을 환영합니다 !'
    # 다음 코드는 POST 요청이 들어왔지만, 필드가 채워지지 않았다면 에러 메시지를 출력한다.
    elif request.method == 'POST':
        msg = 'Please fill out the form !'
    # 다음 코드는 GET 요청이 들어왔을 때, 회원가입 페이지를 렌더링한다.
    return render_template('signup.html', msg=msg)
# 메인 페이지
@app.route("/main")
def index():
    if 'loggedin' in session:  # 로그인 여부를 세션에서 확인
        return render_template("main.html")  # 로그인 되어 있으면 main.html 페이지 렌더링
    return redirect(url_for('login'))  # 로그인 되어 있지 않으면 login 페이지로 리다이렉트
# 마이페이지
@app.route('/mypage.html')  # '/mypage.html' 경로로 요청이 들어오면
def mypage():  # mypage 함수 실행
    return render_template('mypage.html')  # mypage.html 파일을 렌더링하여 반환

if __name__ == '__main__':  # 현재 파일이 실행되는 메인 파일일 경우
    app.run(debug=True)  # Flask 애플리케이션을 debug 모드로 실행

 

6. user.sql : DB

create database ebook default character set utf8 collate utf8_general_ci; -- ebook 데이터베이스 생성 및 문자 인코딩 설정
use ebook -- ebook 데이터베이스 사용
create table user ( -- user 테이블 생성
    account char(30) not null, -- 계정(아이디) 열 생성, null 값 불가능
    password varchar(255) not null, -- 비밀번호 열 생성, null 값 불가능
    username varchar(50) not null, -- 사용자 이름 열 생성, null 값 불가능
    email varchar(100) not null, -- 이메일 열 생성, null 값 불가능
    gender varchar(10) not null, -- 성별 열 생성, null 값 불가능
    birth date not null, -- 생년월일 열 생성, null 값 불가능
    phonenumber varchar(30), -- 전화번호 열 생성, null 값 가능
    primary key(account) -- account 열을 기본키로 설정
) engine=InnoDB default charset=utf8; -- InnoDB 스토리지 엔진 사용 및 문자 인코딩 설정
반응형