[Python - Django] 팝빌 전자세금계산서 SDK 튜토리얼

Django 프레임워크를 사용하는 환경에서 pip를 이용해 팝빌 Python SDK를 추가한 후 전자세금계산서 즉시발행(RegistIssue) SDK 함수를 구현하는 예시입니다.

1. Popbill SDK 추가 팝빌 Python SDK Django Example

① 팝빌 Python SDK를 추가하기 위해 pip install 명령어를 사용하여 패키지를 설치합니다.

$ pip install popbill

② Django 프로젝트의 settings.py 파일에 연동신청시 발급받은 인증정보와 연동환경 설정값을 선언합니다.

연동신청시 발급받은 인증정보로 링크아이디(LinkID)와 비밀키(SecretKey) 값을 변경하시기 바랍니다.

# -*- coding: utf-8 -*-
import os
import sys
import imp
imp.reload(sys)

try:
    sys.setdefaultencoding('UTF8')
except Exception as E:
    pass

#생략
#...
#...

# 링크아이디
LinkID = "TESTER"

# 발급받은 비밀키, 유출에 주의하시기 바랍니다.
SecretKey = "SwWxqU+0TErBXy/9TVjIPEnI0VTUMMSQZtJf3Ed8q3I="

# 연동환경 설정값, 개발용(True), 상업용(False)
IsTest = True

# 인증토큰 IP제한기능 사용여부, 권장(True)
IPRestrictOnOff = True

# 팝빌 API 서비스 고정 IP 사용여부(GA), true-사용, false-미사용, 기본값(false)
UseStaticIP = False

2. 전자세금계산서 즉시발행(RegistIssue) 기능 구현

① Django App에 생성된 views.py 파일에 전자세금계산서 서비스 클래스 객체 생성과 전자세금계산서 즉시발행(RegistIssue) 함수 호출 코드를 추가합니다.


# -*- coding: utf-8 -*-
from django.shortcuts import render
from popbill import TaxinvoiceService, PopbillException, Taxinvoice, TaxinvoiceDetail, Contact, ContactInfo, JoinForm, CorpInfo

from config import settings

# settings.py 작성한 LinkID, SecretKey를 이용해 TaxinvoiceService 객체 생성
taxinvoiceService = TaxinvoiceService(settings.LinkID, settings.SecretKey)

# 연동환경 설정값, 개발용(True), 상업용(False)
taxinvoiceService.IsTest = settings.IsTest

# 인증토큰 IP제한기능 사용여부, 권장(True)
taxinvoiceService.IPRestrictOnOff = settings.IPRestrictOnOff

# 팝빌 API 서비스 고정 IP 사용여부(GA), true-사용, false-미사용, 기본값(false)
taxinvoiceService.UseStaticIP = settings.UseStaticIP

def registIssue(request):
    try:
        # 팝빌회원 사업자번호
        CorpNum = "1234567890"

        # 팝빌회원 아이디
        UserID = "testkorea"

        # [필수] 세금계산서 문서번호, 1~24자리, (영문, 숫자, '-', '_') 조합으로 사업자별로 중복되지 않도록 구성
        MgtKey = "20190830-01"

        # 지연발행 강제여부
        # 발행마감일이 지난 세금계산서를 발행하는 경우, 가산세가 부과될 수 있습니다.
        # 가산세가 부과되더라도 발행을 해야하는 경우에는 forceIssue의 값을 True로 선언
        forceIssue = False

        # 거래명세서 동시작성여부
        writeSpecification = False

        # 거래명세서 동시작성시, 명세서 관리번호, 1~24자리, (영문, 숫자, '-', '_') 조합으로 사업자별로 중복되지 않도록 구성
        dealInvoiceMgtKey = ""

        # 메모
        memo = "즉시발행 메모"

        # 발행안내 메일 제목, 미기재시 기본양식으로 전송
        emailSubject = ""

        # 세금계산서 정보
        taxinvoice = Taxinvoice(

            # [필수] 작성일자, 날짜형식(yyyyMMdd) ex)20190116
            writeDate="20190830",

            # [필수] 과금방향, [정과금(공급자), 역과금(공급받는자)]중 기재
            # 역과금의 경우 역발행세금계산서 발행시에만 사용가능
            chargeDirection="정과금",

            # [필수] 발행형태, [정발행, 역발행, 위수탁] 중 기재
            issueType="정발행",

            # [필수] 영수/청구, [영수, 청구] 중 기재
            purposeType="영수",

            # [필수] 과세형태, [과세, 영세, 면세] 중 기재
            taxType="과세",

            ######################################################################
            #                             공급자 정보
            ######################################################################

            # [필수] 공급자 사업자번호 , '-' 없이 10자리 기재.
            invoicerCorpNum=CorpNum,

            # 공급자 종사업장 식별번호, 필요시 숫자 4자리 기재
            invoicerTaxRegID=None,

            # [필수] 공급자 상호
            invoicerCorpName="공급자 상호",

            # [필수] 공급자 문서번호, 1~24자리, (영문, 숫자, '-', '_') 조합으로
            # 사업자별로 중복되지 않도록 구성
            invoicerMgtKey=MgtKey,

            # [필수] 공급자 대표자 성명
            invoicerCEOName="공급자 대표자 성명",

            # 공급자 주소
            invoicerAddr="공급자 주소",

            # 공급자 종목
            invoicerBizClass="공급자 종목",

            # 공급자 업태
            invoicerBizType="공급자 업태",

            # 공급자 담당자 성명
            invoicerContactName="공급자 담당자명",

            # 공급자 담당자 메일주소
            invoicerEmail="test@test.com",

            # 공급자 담당자 연락처
            invoicerTEL="070-111-222",

            # 공급자 담당자 휴대폰 번호
            invoicerHP='010-111-222',

            # 발행시 알림문자 전송여부 (정발행에서만 사용가능)
            # - 공급받는자 주)담당자 휴대폰번호(invoiceeHP1)로 전송
            # - 전송시 포인트가 차감되며 전송실패하는 경우 포인트 환불처리
            invoicerSMSSendYN=False,

            ######################################################################
            #                            공급받는자 정보
            ######################################################################

            # [필수] 공급받는자 구분, [사업자, 개인, 외국인] 중 기재
            invoiceeType="사업자",

            # [필수] 공급받는자 사업자번호, '-' 제외 10자리
            invoiceeCorpNum="8888888888",

            # 공급자 종사업장 식별번호, 필요시 숫자 4자리 기재
            invoiceeTaxRegID=None,

            # [필수] 공급받는자 상호
            invoiceeCorpName="공급받는자 상호",

            # [역발행시 필수] 공급받는자 문서번호, 1~24자리 (숫자, 영문, '-', '_') 조합으로 사업자별로 중복되지 않도록 구성
            invoiceeMgtKey=None,

            # [필수] 공급받는자 대표자 성명
            invoiceeCEOName="공급받는자 대표자 성명",

            # 공급받는자 주소
            invoiceeAddr="공급받는자 주소",

            # 공급받는자 종목
            invoiceeBizClass="공급받는자 종목",

            # 공급받는자 업태
            invoiceeBizType="공급받는자 업태",

            # 공급받는자 담당자 성명
            invoiceeContactName1="공급받는자 담당자",

            # 공급받는자 담당자 메일주소
            # 팝빌 개발환경에서 테스트하는 경우에도 안내 메일이 전송되므로,
            # 실제 거래처의 메일주소가 기재되지 않도록 주의
            invoiceeEmail1="test@test.com",

            # 공급받는자 연락처
            invoiceeTEL1="070-111-222",

            # 공급받는자 담당자 휴대폰번호
            invoiceeHP1="010-111-222",

            # 공급받는자 담당자 팩스번호
            invoiceeFAX1="070-111-222",

            ######################################################################
            #                          세금계산서 기재정보
            ######################################################################

            # [필수] 공급가액 합계
            supplyCostTotal="100000",

            # [필수] 세액 합계
            taxTotal="10000",

            # [필수] 합계금액, 공급가액 합계 + 세액 합계
            totalAmount="110000",

            # 기재상 '일련번호' 항목
            serialNum="123",

            # 기재상 '현금' 항목
            cash=None,

            # 기재상 '수표' 항목
            chkBill=None,

            # 기재상 '어음' 항목
            note=None,

            # 기재상 '외상미수금' 항목
            credit="",

            # 기재 상 '비고' 항목
            remark1="비고1",
            remark2="비고2",
            remark3="비고3",

            # 기재상 '권' 항목, 최대값 32767
            # 미기재시 kwon=None,
            kwon=1,

            # 기재상 '호' 항목, 최대값 32767
            # 미기재시 ho=None,
            ho=2,

            # 사업자등록증 이미지 첨부여부
            businessLicenseYN=False,

            # 통장사본 이미지 첨부여부
            bankBookYN=False,

            ######################################################################
            #                 수정세금계산서 정보 (수정세금계산서 발행시에만 기재)
            # - 수정세금계산서 관련 정보는 연동매뉴얼 또는 개발가이드 링크 참조
            # - [참고] 수정세금계산서 작성방법 안내 - http://blog.linkhub.com/650
            ######################################################################

            # [수정세금계산서 작성시 필수] 수정세금계산서 정보 수정사유별로 1~6중 선택기재
            # 수정사유코드
            modifyCode=None,

            # [수정세금계산서 작성시 필수] 원본세금계산서의 국세청승인번호 기재
            orgNTSConfirmNum=None
        )

        ######################################################################
        #                           상세항목(품목) 정보
        ######################################################################

        # 상세항목 0~99개 까지 작성가능.
        # 일련번호 (serialNum) 는 1부터 99까지 순차기재.
        taxinvoice.detailList = []

        taxinvoice.detailList.append(
            TaxinvoiceDetail(
                serialNum=1,  # 일련번호, 1부터 순차기재
                purchaseDT="20190830",  # 거래일자, yyyyMMdd
                itemName="품목1",  # 품목
                spec="규격",  # 규격
                qty=1,  # 수량
                unitCost="50000",  # 단가
                supplyCost="50000",  # 공급가액
                tax="5000",  # 세액
                remark="품목비고"  # 비고
            )
        )

        taxinvoice.detailList.append(
            TaxinvoiceDetail(
                serialNum=2,  # 일련번호, 1부터 순차기재
                purchaseDT="20190830",  # 거래일자, yyyyMMdd
                itemName="품목2",  # 품목
                spec="규격",  # 규격
                qty=1,  # 수량
                unitCost="50000",  # 단가
                supplyCost="50000",  # 공급가액
                tax="5000",  # 세액
                remark="품목비고"  # 비고
            )
        )

        ######################################################################
        #                           추가담당자 정보
        # - 세금계산서 발행안내 메일을 수신받을 공급받는자 담당자가 다수인 경우
        #   담당자 정보를 추가하여 발행안내메일을 다수에게 전송할 수 있습니다.
        ######################################################################

        # 최대 5개까지 기재 가능
        taxinvoice.addContactList = []

        taxinvoice.addContactList.append(
            Contact(
                serialNum=1,  # 일련번호, 1부터 순차기재
                contactName="추가담당자 성명",  # 담당자명
                email="test1@test.com"  # 메일주소
            )
        )

        taxinvoice.addContactList.append(
            Contact(
                serialNum=2,  # 일련번호, 1부터 순차기재
                contactName="추가담당자 성명",  # 담당자명
                email="test1@test.com"  # 메일주소
            )
        )

        response = taxinvoiceService.registIssue(CorpNum, taxinvoice, writeSpecification,
                                                 forceIssue, dealInvoiceMgtKey, memo, emailSubject, UserID)

        return render(request, 'response.html', {'code': response.code, 'message': response.message, 'ntsConfirmNum': response.ntsConfirmNum})
    except PopbillException as PE:
        return render(request, 'exception.html', {'code': PE.code, 'message': PE.message})

② 함수 호출결과 코드와 메시지를 출력하는 "/response.html" 파일을 추가합니다.

<html xmlns=" http://www.w3.org/1999/xhtml ">
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>Popbill API Test.</title>
  </head>
  <body>
    <div id="content">
        <p class="heading1">Response</p>
        <br/>
        <fieldset class="fieldset1">
            <ul>
                <li>응답코드 (Response.code) : {{ code }}</li>
                <li>응답메시지 (Response.message) : {{ message }}</li>
                <li>국세청 승인번호 (Response.ntsConfirmNum) : {{ ntsConfirmNum }}</li>
            </ul>
        </fieldset>
    </div>
  </body>
</html> 

③ 웹브라우저에서 페이지를 호출하여 함수호출 결과를 확인합니다.

팝빌 Python SDK 전자세금계산서 Example

기술지원센터

팝빌 기술지원은 유선, 메일, 원격지원 등 다양한 채널을 통해 제공됩니다.

T. 1600-9854   E. code@linkhub.co.kr

연동문의