🌈 프로그래밍
파이참 django 프로젝트 소스 디렉터리 설정
파이참에서 django 프로젝트를 켰을 때 import 구문에서 불러올 수 없는 문제가 있었다.그치만 서버를 로컬에서 실행하는데에는 문제가 없었음.빨간 줄을 없애보자~우선 , + command로 파이참 설정 창을 띄운 후에 프로젝트 구조 섹션으로 이동하면 된다.그러면 소스 폴더와 제외된 폴더, 템플릿 등등을 추가하거나 삭제할 수 있는데,나의 django 프로젝트 같은 경우에는 프로젝트 루트에 `manage.py`가 있는게 아니고 `web` 디렉터리 하위에 존재하기 때문에소스 폴더에 `web`을 추가해주었다.최종 해결 모습
테스트 자동화 하기
Refactoring"Whenever you read [Refactoring], it’s time to read it again. And if you haven’t read it yet, please do before writing another line of code." ?David Heinemeier Hansson, Creator of Ruby on Rails, Founder & CTO at Basecamp Fully Revised and Updated-Includes New Refactorings and Code Examples “Any fool can write code that a computer can understand. Good programmers write code that humans..
unmanaged table에 대한 django test 하는 방법
장고의 모델 클래스에는 Meta 옵션 중 하나로 managed라는 값이 존재한다. 이는 True 또는 False이고 기본값은 True로 설정된다. True로 설정된다면 그 뜻은 다음과 같다. 쉽게 말해 장고가 해당 모델 클래스를 관리한다는 뜻이다. 이를 공식문서에서는 어떻게 표현하고 있냐면, https://docs.djangoproject.com/en/4.2/ref/models/options/#managed Django The web framework for perfectionists with deadlines. docs.djangoproject.com That is, Django manages the database tables’ lifecycles. 즉, 테이블의 수명 주기를 관리한다라고 한다. 테이..
djongo를 설치하는 과정에서 발견한 오류들
Django 프로젝트에서 MongoDB를 사용하기 위해 `djongo` 를 설치하려고 했을 때 발생한 문제와 그 해결방법에 대해 알아보자. 프로젝트의 초기 toml 파일은 다음과 같았다. [tool.poetry.dependencies] python = "^3.10" djangorestframework-simplejwt = "^5.2.2" mysqlclient = "
[ Django ] select_related()와 prefetch_related()
Django를 좀 한다 그러면 이 둘의 개념은 필수적으로 알아야 한다. (그래야 밥벌어 먹고 살 수 있엉..) 기본 개념을 숙지하고 반복해서 실무에 적용할 수 있도록 하여 내 것으로 만들어야겠다! 사용하는 이유? - QuerySet은 기본적으로 Lazy Loading(지연 로딩) 방식을 선택한다. - 하지만 SQL로 한번에 많은 양의 데이터를 가지고오고 싶을 때가 있으며 그럴때 위의 메소드들를 사용한다. - 즉, 관계가 있는 object를 Eager Loading(즉시 로딩) 하기 위해서 사용한다. 이 둘의 차이점? - 1:1, 1:N, N:M의 관계중에 따라 달리 사용되어진다. - 우선 가장 큰 차이점으로는 추가 쿼리가 발생하는지 안하는지이다. 1. select_related - select의 경우 1..
Django Session Cookie Age 알아보고 커스텀하기
Django 프로젝트의 루트 경로에 있는 settings.py에 정의되어 있는 세션 관련 내용이 다음과 같았다. REST_FRAMEWORK REST_FRAMEWORK = { "DEFAULT_AUTHENTICATION_CLASSES": [ "rest_framework.authentication.SessionAuthentication", ], } INSTALLED_APPS INSTALLED_APPS = [ ... "django.contrib.sessions", ... ] MIDDLEWARE MIDDLEWARE = [ ... "django.contrib.sessions.middleware.SessionMiddleware", ... ] API 테스트를 진행하던 도중, 아래와 같은 응답을 받은적이 있었다. { "..
zsh: command not found: mysql
엊그제까지만 해도 mysql 명령어가 잘 먹었었는데,, 무슨 원인인인지는 모르겠지만 바로 zsh: command not found: mysql 에러가 났다.. ~/.zshrc의 PATH를 건드리지도 않았는데.. 해결법은 정말 간단 그 자체였다. mysql-client 를 설치하고, 설치 완료 후 아래의 명령어를 입력해주고 > source ~/.zshrc 로 컴파일 하면 끝!
[ django ] AWS lambda raw sql 에서 django raw sql로 TypeError: not enough arguments for format string 에러
AWS 정상 동작 쿼리문 SELECT -- 생략 DATE_FORMAT(DATE_ADD(m.schedule, INTERVAL 9 HOUR), '%Y.%m.%d %H:%i') schedule, -- 생략 FROM Match WHERE -- 생략 AND DATE_FORMAT(DATE_ADD(m.schedule, INTERVAL 9 HOUR), '%T') between '08:00:00' and '11:00:00' 위의 쿼리의 의미 1. 데이터를 가져오는데 시간 값을 해당 포맷으로 지정하고 가져와! 2. 시간 데이터를 가져오는데 시간값만 가져오고, 해당 시간이 08시부터 11시 사이인 데이터만 가져와! 해당 쿼리를 서버쪽 @shared_task로 이전해야 했기에, 굳이 ORM으로 변경하지 않고 사용하던 쿼리를 ..
[ Django ORM ] 문자열 숫자를 int로 캐스팅해서 정렬해보자.
보통 문자열 숫자를 정렬한다고 하면 .. ["60", "20", "0", "120", "0", "80"] 위와 같이 문자열로 이루어져있는 숫자들이 있다고 가정해보자. 별 다를 것 없이 정렬한다면 어떤 결과가 나올까? 실제 결과는 아래와 같다. ['0', '0', '120', '20', '60', '80'] 0 다음에 120이 바로 나오게 된다. 왜냐하면 너무 당연하게도 앞문자열에 따라 120의 1이 20보다 빠르기 때문이다. 실제 나는 정렬하려고 하는 기준 데이터들은 다음과 같았다. 해당 필드는 문자열이고 문자 + 숫자가 함께 저장되어있는 필드였다. 우선, BAD_WEATHER_ 이라는 문자열은 모두 공통이므로 from django.db.models.functions import Substr Substr..
[ node/express ] 외부 API post 요청 시 json Array 객체를 포함해서 전송하기
외부 API를 사용하려면 외부 api 요청을 하기 위해서는 가장 먼저 제공해주는 API document를 이해하는 것이 첫 번째 단계이다. 어떻게 요청을 보내야 하고 필수 값은 어떤 것이 있는지, 필요한 헤더 정보는 무엇이 있는지 등등 파악해야 한다. 문서도 꼼꼼이 보지 않고 요청을 날리는 바보 같은 행동은 이제 그만~ (제 이야기에요) POST 요청 시 필요한 값 분석 내가 사용하려고 하는 외부 API를 분석해보니 다음과 같은 데이터가 필요했다. path : str method : str header : json object body : json Array path는 요청을 어디로 날릴지에 대한 endpoint이고, method는 요청을 어떻게 할 건지, get인지 post인지.. 그렇지만 나는 npm..