Popen.stdout.readline() работает в Python 3.2, но возвращает пустую строку в Python 3.6

Я использую Popen для запуска процесса telnet через ssh, отправки команд через telnet и проверки процесса на вывод, чтобы отслеживать состояние telnet. Странная вещь, с которой я столкнулся, заключается в том, что код отлично работает с Python 3.2.3, но когда я запускаю его в Python 3.6.5 без изменений кода, он не может получить результат.

я пытался

  • сброс стандартного вывода

  • ожидание до 10 секунд после stdout.write

  • проверил stderr

def nonblockingread(sout):
   fd = output.fileno()
   fl = fcntl.fcntl(fd, fcntl.F_GETFL)
   try:
       return sout.read()
   except:
       return ""

process = Popen(shlex.split("ssh anon@server \"telnet 0 2323\""), stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
print(nonblockingread(process.stdout)) # works for both versions
process.stdin.write(b"start service 4\n")
print(nonblockingread(process.stdout)) # works in 3.2 but not 3.6 (prints empty line)
print(process.stdout.readline()) # also prints empty line in 3.6

Почему вы пишете в читаемый файл process.stdout, а не в записываемый файл process.stdin?

Dan D. 25.04.2019 01:26

Это была опечатка

Belos 25.04.2019 02:10

Кажется, не хватает какого-то кода — например, вы никогда не устанавливаете ничего неблокирующего. Ваша «служба 4» действительно запущена?

Davis Herring 25.04.2019 02:23
Почему в 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 может стать мощным инструментом для создания эффективных и масштабируемых веб-приложений.
5
3
715
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Буферизация была включена по умолчанию в 3.2.4 и 3.3.1, но была случайно отключена в Python 3. Вам нужно flush свой write на process.stdin, чтобы другая сторона что-нибудь увидела.

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