Проблема с импортом files.py в Python

Я думаю, что это довольно простой вопрос, но мне ничего не удалось найти. Извините, если это дубликат.

У меня есть файл с определенными функциями, назовем его main_functions.py.

В этом файле я использую функцию, которую мы можем назвать foo(). Например, в файле main_functions.py может быть что-то вроде этого:

def bar():
    return foo()

foo() определен в другом файле под названием secondary_functions.py.

def foo():
    return 1

Теперь в моем сценарии main я хотел бы импортировать файл, в котором я могу определить foo(), а затем сделать что-то вроде:

from secondary_functions import *    # Here I define foo()
from main_functions import *  

bar()

Если я это сделаю, функция внутри main_functions не сможет найти определения, которые присутствуют в secondary_functions, и я получу сообщение об ошибке:

NameError: name 'foo' is not defined

Для меня очень важно решить эту проблему.

Моя цель - иметь разные файлы с именами secondary_functions1.py, secondary_functions2.py, и т.д., определения foo().

И, чтобы решить проблему, я не хочу каждый раз изменять файл, который зависит от этих определений, например, каждый раз вставляя что-то вроде import secondary_functionsX.py, что решило бы проблему. Я хочу изменить только основной сценарий.

Как мы можем воспроизвести проблему? минимальный воспроизводимый пример облегчит помощь.

mzjn 16.12.2018 10:54

Редактировал вопрос. Надеюсь, что теперь стало более ясно!

spy95 16.12.2018 11:03
Почему в Python есть оператор "pass"?
Почему в Python есть оператор "pass"?
Оператор pass в Python - это простая концепция, которую могут быстро освоить даже новички без опыта программирования.
Некоторые методы, о которых вы не знали, что они существуют в Python
Некоторые методы, о которых вы не знали, что они существуют в Python
Python - самый известный и самый простой в изучении язык в наши дни. Имея широкий спектр применения в области машинного обучения, Data Science,...
Основы Python Часть I
Основы Python Часть I
Вы когда-нибудь задумывались, почему в программах на Python вы видите приведенный ниже код?
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
Алиса и Боб имеют неориентированный граф из n узлов и трех типов ребер:
Оптимизация кода с помощью тернарного оператора Python
Оптимизация кода с помощью тернарного оператора Python
И последнее, что мы хотели бы показать вам, прежде чем двигаться дальше, это
Советы по эффективной веб-разработке с помощью Python
Советы по эффективной веб-разработке с помощью Python
Как веб-разработчик, Python может стать мощным инструментом для создания эффективных и масштабируемых веб-приложений.
1
2
838
3
Перейти к ответу Данный вопрос помечен как решенный

Ответы 3

Кажется, что проблема не в правильном вызове файлов, потому что вы неправильно вызываете pippo, если pippo - глобальная переменная, тогда я не понимаю, почему она не работает. единственный способ решить эту проблему - сказать file.pippo

и если у вас будет несколько файлов с переменной pippo, то лучше не делать их глобальными и вызывать их индивидуально, как я только что вам показал.

другая вещь, которая может быть проблемой, - это если вы определяете pippo внутри функции, которая затем делает его локальной переменной только для этой функции.

И последняя проблема, о которой я могу думать, это если вы используете их в main_functions, и они не были определены в main_functions, и вы не импортируете файлы в main_functions, то есть # in main_functions.py
import secondary_functions

то я не думаю, что main_functions сможет найти функцию и переменную, не делая их аргументами для функции, в которой вы их используете. или снова вы можете сделать что-то вроде file.pippo

Извините, я немного отредактировал вопрос, и теперь Пиппо больше нет. Кстати, я не хочу импортировать secondary_functions в main_functions. Я хочу однозначно выбрать secondary_functions в основном скрипте. Так что я все равно не могу делать secondary_functions.foo ...

spy95 16.12.2018 11:07

Я вижу у тебя проблемы. И снова единственный способ исправить это - вызвать его в bar (), например, «return secondary_functions.foo ()», или снова поставить foo в качестве аргумента для панели функций. И моя последняя идея, которая, как мне кажется, не сработает, - это создать класс с функцией foo () и вызвать его из класса

Aguy 16.12.2018 11:15

После операторов импорта такие переменные, как pippo, стали глобальными переменными в рамках основной программы. Но глобальные переменные не наследуются импортируемыми модулями. Предполагается, что модули могут работать сами по себе как автономные блоки, которые могут быть импортированы любой программой; представьте, что может пойти не так, если они начнут использовать переменные из того, что их импортирует ...

Таким образом, единственный способ сделать это - явно «передать» значения вашему модулю, например, в качестве дополнительных аргументов функции. Вы можете поместить все, что есть в main_functions.py, в класс, а затем заставить ваш основной скрипт передать ему желаемые глобальные переменные в качестве аргументов своей функции построения init, чтобы он мог сохранить их для использования bar() и другими методами.

Спасибо! Я не хотел использовать классы, но с их помощью я решил свою проблему. Но я до сих пор не знаю, есть ли способ решить проблему без использования классов. Я не закрываю вопрос, потому что мне довольно любопытно узнать, есть ли способ преодолеть проблему, не возвращаясь к классу;)

spy95 16.12.2018 12:59
Ответ принят как подходящий

Имя foo импортируется в main.py. foo недоступен в модуле main_functions.py, потому что вы не импортировали его в этот модуль. См. Пространства имен с импортом модулей, чтобы узнать, почему это работает таким образом.

Один из способов сделать то, что вы хотите, - предоставить foo в качестве аргумента для bar(). Пример:

main.py:

from secondary_functions import foo
from main_functions import bar 

bar(foo)

main_functions.py:

def bar(foo):
    return foo()

secondary_functions.py:

def foo():
    return 1

Другие вопросы по теме