selalu keluar error UnboundLocalError: local variable 'ori_code' referenced before assignment

import logging.config
import yaml
import ConfigParser
import glob,sys,os

IN_DIR = 'D:\\DATA\\OUT\\*.hl7'

config = ConfigParser.ConfigParser()
config.read('order_file.ini')

def main():
    logging.debug('main() IN_DIR[%s]' % IN_DIR)
    for hl7_file in glob.glob(IN_DIR):
        logging.info(hl7_file)
        with open(hl7_file) as f_open:
            f_content = f_open.readlines()
            logging.debug(f_content)
            for l in f_content:
                if l[:3] == 'PV1':
                    logging.info('PV1')
                    l_sp = l.split('|')
                    logging.info(l_sp[3])
                    ori_code = l_sp[3]
                    #ori_code = l_sp[3].split('.')[0]
                    #ori_name = l_sp[3].split('^')[3]
        #logging.info('ori_code [%s] ori_name[%s]' % (ori_code,ori_name))
        logging.info('ori_code [%s]' % (ori_code))
        if ori_code == '010108': #FOLDER MCU
            f_name = os.path.basename(hl7_file)
            out_fname = OUT_DIR_RUTIN+f_name
            logging.info('to [%s]' % (out_fname))
            os.rename(hl7_file,out_fname)
        elif ori_code == '010113': #FOLDER RUTIN
            f_name = os.path.basename(hl7_file)
            out_fname = OUT_DIR_MCU+f_name
            logging.info('to [%s]' % (out_fname))
            os.rename(hl7_file,out_fname)
        else:
            f_name = os.path.basename(hl7_file)
            out_fname = OUT_DIR_OTHERS+f_name
            logging.info('to [%s]' % (out_fname))
            os.rename(hl7_file,out_fname)

if __name__ == "__main__":
    with open('order_file.yaml', 'rt') as f:
        config = yaml.safe_load(f.read())
        logging.config.dictConfig(config)
    main()


avatar matgefer
@matgefer

1 Kontribusi 0 Poin

Diperbarui 1 bulan yang lalu

1 Jawaban:

UnboundLocalError: local variable 'ori_code' terjadi karena ori_code belum di definisikan sebelumnya,,, jadi tetep harus di identifikasi dulu walau dengan NONE atau false (buat pv1 nya)

def main():
    logging.debug('main() IN_DIR[%s]' % IN_DIR)
    for hl7_file in glob.glob(IN_DIR):
        logging.info(hl7_file)
        ori_code = None  # Inisialisasi ori_code
        pv1_found = False  # Flag untuk menandai apakah PV1 ditemukan
        
        with open(hl7_file) as f_open:
            f_content = f_open.readlines()
            logging.debug(f_content)
            for l in f_content:
                if l[:3] == 'PV1':
                    logging.info('PV1')
                    l_sp = l.split('|')
                    try:
                        ori_code = l_sp[3]
                        logging.info(ori_code)
                        pv1_found = True
                        break  # Keluar dari loop setelah menemukan PV1
                    except IndexError:
                        logging.warning("PV1 line doesn't have expected number of elements")
        
        if not pv1_found:
            logging.warning("No PV1 line found in file: %s" % hl7_file)
            continue  # Lanjut ke file berikutnya
        
        if ori_code is None:
            logging.warning("Unable to extract ori_code from file: %s" % hl7_file)
            continue  # Lanjut ke file berikutnya

        logging.info('ori_code [%s]' % ori_code)
        
        f_name = os.path.basename(hl7_file)
        if ori_code == '010108':  # FOLDER MCU
            out_fname = OUT_DIR_RUTIN + f_name
        elif ori_code == '010113':  # FOLDER RUTIN
            out_fname = OUT_DIR_MCU + f_name
        else:
            out_fname = OUT_DIR_OTHERS + f_name
        
        logging.info('to [%s]' % out_fname)
        os.rename(hl7_file, out_fname)
avatar yukaristel
@yukaristel

34 Kontribusi 31 Poin

Dipost 1 bulan yang lalu

Login untuk ikut Jawaban