재미로 하는 찬의아빠의 일상,리뷰 블로그
TODAY TOTAL
01-02 19:47
반응형
파이썬 (2)
[개발팁] 실무에 GPT 활용하기 : 실무를 넘어 일상의 효율화까지
반응형

서문

 

안녕하세요! 저는 주로 C# 개발을 하며 하루를 보내는 평범한 개발자입니다. 요즘 들어 업무 속에서 가장 많이 체감하는 기술 혁신은 바로 GPT 같은 생성형 AI의 등장입니다. 하지만 놀랍게도, 저는 GPT를 실무 코드를 작성하는 데 주로 사용하지는 않습니다.

대신, GPT는 제 업무의 '잡무'를 수월하게 해주는 조력자 역할을 톡톡히 하고 있습니다. 예를 들어 문서를 정리하거나, 반복적인 텍스트 작업을 줄이고, 머리를 식히고 싶은 순간 아이디어를 빠르게 제시해주는 등 작은 부분에서 큰 도움을 받고 있습니다.

흥미로운 점은 이런 AI 도구가 비개발자 분들에게도 아주 쉽게 적용될 수 있다는 것입니다. 그래서 이번 글에서는 GPT를 활용해 실생활이나 업무에서 작은 잡무를 해결하는 방법을 소개해보려 합니다. 개발자뿐만 아니라 누구라도 따라할 수 있는 팁들을 다룰 예정이니, 가볍게 읽어보시고 오늘부터 바로 활용해보세요!

그럼, GPT와 함께 조금 더 스마트한 하루를 만들어 볼까요?

 

본문

 

바로GPT 에게 시켜보겠습니다.

 

요구사항은 아래와 같습니다.

  • 사용자가 입력한 경로의 파일이 있는지
  • 파일의 버전 정보 출력
  • 주기적으로 갱신
  • 다음 동작시에도 이전 목록 보여주기
  • UI 프로그래밍

입니다.

 

결과

 

순식간에 117 줄 짜리 파이썬 프로그램이 완성되었습니다.

왼편이 제가 질문한 내용이고, 오른편이 그 결과물입니다.

질문은 별거 없죠?

 

이젠 Visual studio code 에 넣고 실행해 보겠습니다.

 

 

이런 UI 를 가지고 있고, Add File 을 통해 경로를 추가할 수 있고,

 

 

파일이 없는 경우에는

 

 

파일이 없어 버전 확인을 할수 없는 상태를 사용자에게 표시해 줍니다.

 

정말 놀랍지 않나요??!!

 

마무리 : GPT 를 활용한 간단한 파이썬 자동화의 힘

 

이번에 살펴본 간단한 파이썬 프로그램은 놀라운 정확도와 함께 업무 효율을 극대화하는 결과를 보여주었습니다. 특히 GPT를 활용해 반복작업을 손쉽게 자동화하는 과정은, 복잡한 개발 지식이 없어도 누구나 시도할 수 있다는 점에서 매우 매력적이죠.

그러나 여기서 가장 중요한 포인트는 GPT에게 어떻게 명령하느냐입니다. 명확하고 구체적인 지시를 통해 GPT의 잠재력을 극대화할 수 있습니다.

 

  • 정확하게 요구사항을 설명하기: 무엇을 원하고, 어떤 결과를 기대하는지 명확하게 전달해야 합니다.
  • 단계별로 명령하기: GPT는 한 번에 모든 것을 처리하는 것도 가능하지만, 단계별로 나눠서 작업을 지시하면 더 정확한 결과를 얻을 수 있습니다.
  • 검증하고 보완하기: GPT의 답변은 놀랍지만 언제나 최종 검토와 보완이 필요합니다. 이 과정을 통해 완성도 높은 결과물을 얻을 수 있습니다.

결국 GPT의 사용법은 복잡하지 않습니다. 핵심은 어떻게 적절하게 활용할지를 고민하고 작은 작업부터 실험해보는 것입니다. 단순 반복작업 하나만 해결해도 그 시간과 에너지를 더 중요한 업무에 투자할 수 있으니까요.

 

이제 여러분도 GPT를 활용해 업무의 잡무를 줄이고, 진짜 중요한 일에 집중해보세요. 놀라운 업무 효율이 바로 여러분의 손에 달려있습니다!

 

진짜 마무리

 

이 포스팅의 대부분의 글은 GPT 를 통하여 작성되었습니다.

 

GPT 의 위대함에, 그리고 그걸 만든 인류에 찬사를 보냅니다.

반응형
  Comments,     Trackbacks
[python3 & 2] 쓰레드 thread 에서 반환값 return value 얻는 방법은?
반응형

thread는 프로그램에 여러 로직 간에 동시성을 갖게 해주는 아주 중요한 요소입니다.

 

보통의 프로그램은 하나의 로직으로만 수행되지 않고 여러 로직이 동시적으로 수행되어 지게 됩니다.

 

오늘 포스팅에서는 쓰레드 thread 에서 반환값 return value 를 얻는 방법에 대하여 포스팅 하려고 합니다.


방법1.  전역번수 사용

일반적으로 쓰레드를 시작하게 되면 반환값은 없이 해당 쓰레드는 로직을 마치면 자동으로 종료되게 됩니다.

그 전에 원하는 값을 공통으로 접근 할 수 있는 변수에 저장할 수 있다면 반환값이 있는 함수처럼 사용할 수 있게 됩니다.

 

from threading import Lock
from threading import Thread

#전역변수
data_list = []
lock_for_data_list = Lock()

def some_fuction():
	#전역변수를 함수 내에서 사용하기 위하여 내부 선언
	global data_list
	data = None
    
	#some logic...
    
	#다른 쓰레드에서 접근을 막기 위한 lock
	lock_for_data_list.acquire()
	data_list.append(data)
	lock_for_data_list.release()
    
def main():
	global data_list
    
	t = Thread(target=some_function)
	t.start()
    
	t.join()
	print(data_list)
    
	return
    
if __name__ == '__main__':
	main()

위 코드에는 세가지 중요한 지점이 있습니다.

첫번째는 정보를 공유할 전역 변수 입니다. 함수 바깥쪽에 사용할 변수를 선언한 뒤, 사용할 함수 안에서 global 키워드와 함께 내부 선언을 해주시면 사용할 준비가 되게 됩니다.

 

두번째는 전역변수 공유 시, dead lock 등 오류를 발생을 방지하기 위한 Lock 입니다. 동시에 같은 데이터에 접근하게 될 경우, 프로그램에 치명적인 오류가 발생하거나 데이터가 부정확해지는 일이 발생할 수 있으므로, 한번에 한 쓰레드에서만 접근할 수 있도록 Lock() 을 사용하여 구역을 묶어 두는것이 일반적입니다.

 

세번째는 쓰레드 Thread 종료 시까지 기다릴 수 있도록 하는 join() 입니다. join() 사용 시, 해당 쓰레드의 함수가 종료될 때까지 기다리게됩니다. 

 

위 세가지 내용이 모두 위의 코드에 쓰였으니 참고 하시면 좋겠습니다.

 

방법2. Thread 클래스를 상속받아 값을 반환하는 클래스

간단하게 코드부터 소개하고 사용법을 공유하겠습니다.(python3)

from threading import Thread

class ThreadWithReturnValue(Thread):
    
    def __init__(self, group=None, target=None, name=None,
                 args=(), kwargs={}, Verbose=None):
        Thread.__init__(self, group, target, name, args, kwargs)
        self._return = None

    def run(self):
        if self._target is not None:
            self._return = self._target(*self._args,
                                                **self._kwargs)
    def join(self, *args):
        Thread.join(self, *args)
        return self._return

위에 작성된 ThreadWithReturnValue 클래스는 Thread 클래스를 상속받아 init 과 run, join 함수를 재정의 하였습니다. (출처 :

class ThreadWithReturnValue(Thread):
    def __init__(self, group=None, target=None, name=None,
                 args=(), kwargs={}, Verbose=None):
        Thread.__init__(self, group, target, name, args, kwargs, Verbose)
        self._return = None
    def run(self):
        if self._Thread__target is not None:
            self._return = self._Thread__target(*self._Thread__args,
                                                **self._Thread__kwargs)
    def join(self):
        Thread.join(self)
        return self._return

 

사용방법은 일반적인 thread 의 사용법과 모두 동일하지만 join 에 반환값이 발생하게 된다.

def foo(bar):
    print 'hello {0}'.format(bar)
    return "foo"

twrv = ThreadWithReturnValue(target=foo, args=('world!',))

twrv.start()
print twrv.join()   # prints foo

위 소개한 두가지 방법을 개념만 잘 잡고 있다면 thread 를 사용하는 것이 어렵지 않게 될 것입니다.

 

더 좋은 방법이 있다면 소개해 주시면 감사드리겠습니다^^

 

이상 포스팅 마치겠습니다.

 

찾아와 주신 모든 분들께 감사드립니다(_ _)

반응형
  Comments,     Trackbacks