Python os.path.join() - не будет правильно комбинироваться

Я хочу сохранить некоторые файлы в подкаталоге текущего каталога, но по какой-то причине, даже если Python «успешно» сохраняет выходные файлы, каталог нигде не отображается.

com_path = './'
out_f = "output"
crop_f = "1-cropped"
(…)
curr_path = os.path.join(com_path, out_f, crop_f)
for elem in images:
    img = img_trim(elem['img'])
    filename = curr_path + 'p_%(p_num)s, (%(orig_name)s)%(ext)s' % elem
    cv2.imwrite(filename, img)
print(curr_path)
>>> ./output\1-cropped
print(com_path)
>>> ./

Как ни странно, при использовании (изначально я написал здесь curr_path вместо com_path, что было ошибкой):

filename = com_path + 'p_%(p_num)s, (%(orig_name)s)%(ext)s' % elem

Все работает отлично и сохраняет нужные файлы в папке сценария .py.

Из того, что я узнал из других тем и официальной документации, это должно работать, а почему нет?

РЕДАКТИРОВАТЬ: согласно запросу:

print(os.getcwd())
>>> C:\Users\iyoossaev\Desktop\Index Cards\tester

где это должно быть

print(filename)
>>> ./p_71, (p0089).png
>>> ./p_72, (p0090).png
>>> ./p_73, (p0091).png
>>> ./p_74, (p0092).png

Файлы не пустые, когда я использую "com_path" все работает (как для загрузки, так и для сохранения) они генерируются как положено. Изменение каталога сохранения приводит к путанице (без изменения каталога загрузки).

РЕДАКТИРОВАНИЕ 2: я решил вставить весь код, чтобы быть уверенным. Программа предназначена для загрузки изображений, преобразования их в черно-белые, поиска релевантного текста с использованием среднего значения пикселей в строке/столбцах и обрезки их, а затем сохранения результатов с измененным именем. Все работает, за исключением случаев, когда я пытаюсь поместить их в подпапку. Образец изображения для тестирования: https://imgur.com/X2mPZr0.

# IndexCardSplitter
import cv2      # biblioteka do obróbki 
import os       # operating system-specific
import re       # RegEx
import numpy    # obliczenia matematyczne

p_num_off = -18 
t_thresh_hor = 210.0
t_thresh_ver = 240.0
t_thresh_m = 25


com_path = os.getcwd()
# com_path = '.'
filenames = os.listdir(com_path)
filenames = [ f for f in filenames if os.path.isfile(os.path.join(com_path, f)) and re.match('[^\_]*\.png$', f) ]

out_f = "output"
crop_f = "1-cropped"
col_f = "2-columns"
def_f = "3-definitions"


def name_mod(filename):
    elements = re.match("(p0{1,}([1-9][^\.]*?))(\.....?$)", filename)
    orig_name = elements.group(1)
    p_num = str(int(elements.group(2)) + p_num_off)
    ext = elements.group(3)
    return{'orig_name':orig_name, 'p_num':p_num, 'ext':ext}


def load_images(filenames):
    images = []
    for f in filenames:
        print(f)
        img_t = cv2.imread(os.path.join(com_path,f), cv2.IMREAD_GRAYSCALE)
        thresh, img_t = cv2.threshold(img_t, 128, 255, cv2.THRESH_OTSU)
        dictionary = name_mod(f)
        dictionary['img'] = img_t
        images.append(dictionary)
    return images


def img_trim(image):
    height, width = image.shape
    height = height - 1
    width = width - 1

    top_trim = 0
    bot_trim = height
    left_trim = 0
    right_trim = width

    i = 0           # GÓRA
    while i < height and top_trim == 0:
        row = image[i, 0:-1]
        if numpy.mean(row) < t_thresh_hor:
            top_trim = i
        i = i + 1

    i = height      # DÓŁ
    while i > 0 and bot_trim == height:
        row = image[i, 0:-1]
        if numpy.mean(row) < t_thresh_hor:
            bot_trim = i
        i = i - 1

    i = 0           # LEWO
    while i < width and left_trim == 0:
        col = image[0:-1, i]
        if numpy.mean(col) < t_thresh_ver:
            left_trim = i
        i = i + 1

    i = width       # PRAWO
    while i > 0 and right_trim == width:
        col = image[0:-1, i]
        # col = image[0:-1, 2700]
        if numpy.mean(col) < t_thresh_ver:
            right_trim = i
        i = i - 1

    top_trim = top_trim - t_thresh_m
    bot_trim = bot_trim + t_thresh_m
    left_trim = left_trim - t_thresh_m
    right_trim = right_trim + t_thresh_m

    image = image[top_trim:bot_trim, left_trim:right_trim]
    return(image)


print('*'*40)

# curr_path = os.path.join(os.getcwd(), out_f, crop_f)
# print(curr_path)
print(com_path)
for elem in images:
    img = img_trim(elem['img'])
    # filename = os.path.join(os.getcwd(), out_f, crop_f, 'p_%(p_num)s, (%(orig_name)s)%(ext)s' % elem)
    filename = com_path + 'p_%(p_num)s, (%(orig_name)s)%(ext)s' % elem
    print(filename)
    cv2.imwrite(filename, img)

Имена входных файлов: p0089.png, p0090.png и т. д.


person MrVocabulary    schedule 14.02.2017    source источник
comment
Возможно, images - это пустой список? Поместите print(filename) в свою петлю. Или, возможно, ваш текущий рабочий каталог не соответствует вашим ожиданиям? Поместите print(os.getcwd()) куда-нибудь. В противном случае отредактируйте свой вопрос, включив в него короткую полную программу, демонстрирующую проблему. См. минимальный воспроизводимый пример для получения дополнительной информации.   -  person Robᵩ    schedule 15.02.2017
comment
Разве это не должно быть filename = os.path.join(curr_path, 'p_%(p_num)s, ...'%elem)?   -  person Aran-Fey    schedule 15.02.2017
comment
Обновлено по запросу. @Rawing делать то, что вы предложили, было моим первоначальным способом, но он делает то же самое, то есть ошибка не возвращается, вроде все в порядке, но папки/файлов нигде нет.   -  person MrVocabulary    schedule 15.02.2017
comment
Вы пробовали заменить com_path = './' на com_path = 'os.getcwd()'? В противном случае вы хотите быть очень уверены в том, что разрешает './'!   -  person Son of a Beach    schedule 15.02.2017
comment
@Son of a Beach у меня есть, и он дает странные результаты — пожалуйста, смотрите мой обновленный пост и мой ответ Дмитрию Рубановичу.   -  person MrVocabulary    schedule 15.02.2017


Ответы (1)


Попробуйте установить com_path на '.' или os.getcwd(). os.path.join не заменяет косую черту на os.sep.

person Dmitry Rubanovich    schedule 14.02.2017
comment
Использование com_path = os.getcwd() позволяет мне получить следующий результат печати: C:\Users\iyoossaev\Desktop\Index Cards\testerp_71, (p0089).png, но использование '.' работает нормально, заставляя меня печатать: .p_71, (p0089).png (и они появляются с этой точкой впереди в рабочем каталоге). С помощью filename = os.path.join(os.getcwd(), out_f, crop_f, 'p_%(p_num)s, (%(orig_name)s)%(ext)s' % elem) напечатайте идеальный путь, но с файлами ничего не происходит… - person MrVocabulary; 15.02.2017
comment
похоже, вы перешли на использование + вместо os.path.join. os.path.join объединит элементы пути и имя файла, используя системный разделитель (os.sep). Это «\» в Windows и «/» в Unix. Я не думаю, что filename = com_path + 'p_%(p_num)s, (%(orig_name)s)%(ext)s' % elem вставит разделители. Если вы хотите сделать это вручную и создать полное имя пути самостоятельно, вам также следует добавить символ-разделитель (os.path) между элементами пути. - person Dmitry Rubanovich; 16.02.2017
comment
Хорошо, этот ваш последний комментарий был тем, что нужно было моей тупой заднице — теперь это работает как шарм :) Но я также предполагал, что запись файла в несуществующую подпапку автоматически создаст его… - person MrVocabulary; 16.02.2017