suchen
HeimBackend-EntwicklungPython-TutorialPython ruft einen externen Unterprozess auf, um asynchrone Standardeingaben und -ausgaben über Pipes zu implementieren

Normalerweise stoßen wir auf solche Anforderungen: Um ein komplexes Funktionsmodul über C oder andere Sprachen auf niedrigerer Ebene zu implementieren, müssen wir eine webbasierte Demo erstellen und Daten abfragen. Aufgrund der Leistungsfähigkeit und Einfachheit der Python-Sprache eignet sie sich sehr gut zum Erstellen von Demos. Die Funktionen des Flask-Frameworks und des Jinja2-Moduls bieten Python praktische Webentwicklungsfunktionen. Gleichzeitig kann Python problemlos mit Codes in anderen Sprachen interagieren. Daher wählen wir Python als Tool für die Demo-Entwicklung. Gehen Sie davon aus, dass das Modul, das wir aufrufen müssen (das die zugrunde liegenden Dienste bereitstellt), Daten in einer Schleife über die Standardeingabe liest und die Ergebnisse nach der Verarbeitung in die markierte Ausgabe schreibt. Dieses Szenario kommt in der Linux-Umgebung sehr häufig vor und basiert auf der leistungsstarken Umleitungsfunktion von Linux . Leider weist das zugrunde liegende Modul jedoch einen umfangreichen Initialisierungsprozess auf, sodass wir den untergeordneten Prozess, der das zugrunde liegende Modul aufruft, nicht für jede Abfrageanforderung erneut starten können. Die Lösung besteht darin, den untergeordneten Prozess nur einmal zu starten und dann für jede Anfrage über eine Pipe mit dem untergeordneten Prozess zu interagieren.

Das Unterprozessmodul von Python kann problemlos Unterprozesse generieren, ähnlich den Linux-Systemaufrufen fork und exec. Das Popen-Objekt des Unterprozessmoduls kann externe ausführbare Programme auf nicht blockierende Weise aufrufen. Daher verwenden wir das Poen-Objekt, um unsere Anforderungen zu erfüllen. Wenn wir Daten in die Standardeingabe stdin des Unterprozesses schreiben möchten, müssen wir beim Erstellen des Popen-Objekts den Parameter stdin als subprocess.PIPE angeben. Wenn wir Daten aus der Standardausgabe des Unterprozesses lesen müssen, müssen wir dies tun Beim Erstellen eines Popen-Objekts müssen Sie den Parameter stdout als subprocess.PIPE angeben. Schauen wir uns zunächst ein einfaches Beispiel an:

from subprocess import Popen, PIPE
p = Popen('less', stdin=PIPE, stdout=PIPE)
p.communicate('Line number %d.\n' % x)

Die Kommunikationsfunktion gibt ein Tupel (stdoutdata, stderrdata) zurück, das die Standardausgabe des untergeordneten Prozesses und die Ausgabedaten-Markierungsfehler enthält . Da jedoch die Kommunikationsfunktion des Popen-Objekts den übergeordneten Prozess blockiert und auch die Pipe schließt, kann jedes Popen-Objekt die Kommunikationsfunktion nur einmal aufrufen. Bei mehreren Anforderungen muss das Popen-Objekt neu generiert werden (Neuinitialisierung des untergeordneten Prozesses). die unsere Bedürfnisse nicht befriedigen können.

Daher können wir unsere Bedürfnisse nur erfüllen, indem wir Daten in die stdin- und stdout-Objekte des Popen-Objekts schreiben und lesen. Leider wird das Unterprozessmodul jedoch standardmäßig nur einmal ausgeführt und liest die Standardausgabe, wenn der Unterprozess beendet wird. Sowohl der Unterprozess als auch os.popen* erlauben nur eine einmalige Eingabe und Ausgabe, und die Ausgabe darf nur gelesen werden, wenn der Prozess beendet wird.

Nach einigen Recherchen habe ich herausgefunden, dass der Unterprozess über die Funktion fcntl verarbeitet werden kann Das fcntl-Modul Die Standardausgabe des Prozesses wird in einen nicht blockierenden Modus geändert, um unseren Zweck zu erreichen. Dieses Problem, das mich schon lange beschäftigt, wurde endlich perfekt gelöst. Der Code lautet wie folgt:

#!/usr/bin/python                                                                                                                                                      
# -*- coding: utf-8 -*-
# author: weisu.yxd@taobao.com
from subprocess import Popen, PIPE
import fcntl, os
import time
class Server(object):
  def __init__(self, args, server_env = None):
    if server_env:
      self.process = Popen(args, stdin=PIPE, stdout=PIPE, stderr=PIPE, env=server_env)
    else:
      self.process = Popen(args, stdin=PIPE, stdout=PIPE, stderr=PIPE)
    flags = fcntl.fcntl(self.process.stdout, fcntl.F_GETFL)
    fcntl.fcntl(self.process.stdout, fcntl.F_SETFL, flags | os.O_NONBLOCK)
  def send(self, data, tail = '\n'):
    self.process.stdin.write(data + tail)
    self.process.stdin.flush()
  def recv(self, t=.1, e=1, tr=5, stderr=0):
    time.sleep(t)
    if tr < 1:
        tr = 1 
    x = time.time()+t
    r = &#39;&#39;
    pr = self.process.stdout
    if stderr:
      pr = self.process.stdout
    while time.time() < x or r:
        r = pr.read()
        if r is None:
            if e:
                raise Exception(message)
            else:
                break
        elif r:
            return r.rstrip()
        else:
            time.sleep(max((x-time.time())/tr, 0))
    return r.rstrip()
if __name__ == "__main__":
  ServerArgs = [&#39;/home/weisu.yxd/QP/trunk/bin/normalizer&#39;, &#39;/home/weisu.yxd/QP/trunk/conf/stopfile.txt&#39;]
  server = Server(ServerArgs)
  test_data = &#39;在云端&#39;, &#39;云梯&#39;, &#39;摩萨德&#39;, &#39;Alisa&#39;, &#39;iDB&#39;, &#39;阿里大数据&#39;
  for x in test_data:
    server.send(x)
    print x, server.recv()

Darüber hinaus müssen Sie beim Aufruf einiger externer Programme möglicherweise die entsprechenden Umgebungsvariablen wie folgt angeben:

  my_env = os.environ
  my_env["LD_LIBRARY_PATH"] = "/path/to/lib"
  server = server.Server(cmd, my_env)

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Was sind einige gängige Operationen, die an Python -Arrays ausgeführt werden können?Was sind einige gängige Operationen, die an Python -Arrays ausgeführt werden können?Apr 26, 2025 am 12:22 AM

PythonarraysSupportvariousoperationen: 1) SlicicingExtractsSubsets, 2) Anhang/Erweiterungen, 3) Einfügen von PlaceSelementsatspezifischePositionen, 4) Entfernen von Delettel, 5) Sortieren/ReversingChangesorder und 6) compredewlistenwlists basierte basierte, basierte Zonexistin

In welchen Anwendungsarten werden häufig Numpy -Arrays verwendet?In welchen Anwendungsarten werden häufig Numpy -Arrays verwendet?Apr 26, 2025 am 12:13 AM

NumpyarraysaresessentialForApplicationsRequeeFoughnumericalComputations und Datamanipulation

Wann würden Sie ein Array über eine Liste in Python verwenden?Wann würden Sie ein Array über eine Liste in Python verwenden?Apr 26, 2025 am 12:12 AM

UseanArray.ArrayoveralistinpythonwhendealingwithhomogenousData, Performance-CriticalCode, OrInterfacingwithCcode.1) HomogenousData: ArraysSavemoryWithtypedElements.2) Performance-CriticalCode: ArraySaveMoryWithtypedElements.2) Performance-CriticalCode: ArraysFerbetterPerPterPerProrMtorChorescomeChormericalcoricalomancomeChormericalicalomentorMentumscritorcorements.3) Interf

Werden alle Listenoperationen von Arrays unterstützt und umgekehrt? Warum oder warum nicht?Werden alle Listenoperationen von Arrays unterstützt und umgekehrt? Warum oder warum nicht?Apr 26, 2025 am 12:05 AM

Nein, NOTALLLISTOPERATIONSARESURDEDBYARAYS UNDVICEVERSA.1) ArraysDonotsupportdynamicoperationslikeAppendorinStResizing, die impactSperformance.2) listsDonotguaranteConstantTimeComplexityfordirectAccesslikearraysDo.

Wie können Sie in einer Python -Liste auf Elemente zugreifen?Wie können Sie in einer Python -Liste auf Elemente zugreifen?Apr 26, 2025 am 12:03 AM

ToaccesselementSinapythonlist, verwenden Indexing, Negativindexing, Slicing, Oriteration.1) IndexingStartsat0.2) NegativeIndexingAccessses aus der THEend.3) SlicingExtractSporions.4) itererationSforloopsorenumerate.AlwaySChEckLegthtoavoidIndexerror.

Wie werden Arrays im wissenschaftlichen Computer mit Python verwendet?Wie werden Arrays im wissenschaftlichen Computer mit Python verwendet?Apr 25, 2025 am 12:28 AM

Arraysinpython, besondersvianumpy, arecrucialInScientificComputingFortheirefficience undvertilität.1) Sie haben festgelegt, dass die Fornerikerne, Datenanalyse und Machinelarning.2) Numpy'SimplementationIncensuresFasteroperationsdanpythonlisten.3) Araysensableableableableableableableableableableableableableableableableableableableableableableableableableable

Wie gehen Sie mit verschiedenen Python -Versionen im selben System um?Wie gehen Sie mit verschiedenen Python -Versionen im selben System um?Apr 25, 2025 am 12:24 AM

Sie können verschiedene Python -Versionen mithilfe von Pyenv, Venv und Anaconda verwalten. 1) Verwalten Sie PYENV, um mehrere Python -Versionen zu verwalten: Installieren Sie PyEnv, setzen Sie globale und lokale Versionen. 2) Verwenden Sie VenV, um eine virtuelle Umgebung zu erstellen, um Projektabhängigkeiten zu isolieren. 3) Verwenden Sie Anaconda, um Python -Versionen in Ihrem Datenwissenschaftsprojekt zu verwalten. 4) Halten Sie das System Python für Aufgaben auf Systemebene. Durch diese Tools und Strategien können Sie verschiedene Versionen von Python effektiv verwalten, um den reibungslosen Betrieb des Projekts zu gewährleisten.

Was sind einige Vorteile bei der Verwendung von Numpy -Arrays gegenüber Standard -Python -Arrays?Was sind einige Vorteile bei der Verwendung von Numpy -Arrays gegenüber Standard -Python -Arrays?Apr 25, 2025 am 12:21 AM

NumpyarrayShaveseveraladVantagesOverStandardPythonArrays: 1) SiearemuchfasterDuetoc-basiert, 2) sie istaremoremory-effizient, insbesondere mit mit LaShlargedatasets und 3) sie können sich mit vektorisierten Funktionsformathematical und Statistical opertical opertical opertical operticaloperation, Making

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

MinGW – Minimalistisches GNU für Windows

MinGW – Minimalistisches GNU für Windows

Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

PHPStorm Mac-Version

PHPStorm Mac-Version

Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor