草庐IT

python进程间通信

全部标签

python - 如何在 Python 中运行/与 Golang 可执行文件交互?

我在Windows上有一个名为cnki-downloader.exe的命令行Golang可执行文件(在此处开源:https://github.com/amyhaber/cnki-downloader)。我想在Python中运行这个可执行文件,并与之交互(获取它的输出,然后输入一些东西,然后获取输出,等等)这是一个命令行程序,所以我认为它与MSVC构建的普通Windows命令行程序相同。我的代码是这样的:#coding=gbkfromsubprocessimportPopen,PIPEp=Popen(["cnki-downloader.exe"],stdin=PIPE,stdout=PI

http - TCP 是同一主机中 Go 程序之间通信的最佳方法吗?

假设我有两个独立的Go程序在我的本地主机上运行,​​就性能而言,TCP是否是在两个程序之间传输数据的最佳方法? 最佳答案 简短的回答是否定的。TCP/IP堆栈很慢,尤其是TCP部分。因此,就性能而言,您最好使用本地进程间通信方法,例如应用程序或Unix套接字之间的共享内存。如果您必须使用网络堆栈进行通信(例如,您计划在主机之间移动应用程序),那么UDP或原始套接字是性能方面的最佳选择。只有当你:必须使用网络并且您需要一个可靠的通信channel,那么TCP是一个不错的选择。因此,只需浏览您的要求并确定它是否是最适合您的方法。

go - 为什么我从 golang 错误地运行 python 脚本

import("fmt""os/exec""bytes")funcmain(){cmd:="/root/hi.py>/root/1.log"out,err:=exec.Command("python","-c",cmd).Output()fmt.Printf("Out:%s",string(out))fmt.Printf("Err:%s",err.Error())}错误:没有这样的文件错误:/root/hi.py>/root/1.log//hi.py#!/usr/bin/pythonprint('helloworld') 最佳答案

docker - 如何让两个运行 flask 服务和 golang 服务的 docker 容器相互通信?

我有一个flask服务通过docker-compose在端口5000上运行。同样,我有一个不同的go服务通过另一个docker-compose在端口8000上运行。Golang服务需要调用在5000上运行的flaskAPI。我是在让go服务调用flask服务时遇到麻烦。我尝试添加docker-network但失败了。与单个docker-compose相比,通过不同的docker-compose运行这两种服务的优缺点是什么?(顺便说一句,我无法在单个docker-compose中成功运行它们)。dockerpsrunningboththecontainers.FlaskDocker组合v

python - golang 像 python 一样定义 dict,并将值附加到 dict 中的列表

我是新手,正在尝试实现如下所示的类似python的嵌套结构,我无法在golang中定义空字典/映射,它可以包含特定结构/类对象的列表,并且在遍历数据时我不是能够在map/dict中附加项目...我将非常感谢对此的任何帮助...谢谢items=[("item1",someObj1),("item2",someObj2),("item3",someObj3),("item3",someObj5),("item1",someObj4),]rectors={}foritem,objinitems:try:rectors[item].append(obj)exceptKeyError:recto

multithreading - 是否应该在长时间运行的进程中留下空闲线程?

我正在创建一个旨在长期运行并监听工作的go程序。当它收到请求时,它会在进程队列上运行工作。我是golang和系统编程的新手,所以我的问题是:我应该在程序启动时启动进程队列(有多个空闲工作线程)(它们会一直坐在那里直到工作开始)还是应该我在工作到达时启动它们并在完成时关闭它们?我不清楚多个空闲线程对整个系统的影响,但我假设因为它们是空闲的,所以在工作到达之前不会有任何影响。也就是说,我想确保我的程序是一个“好邻居”并且尽可能高效。--编辑--澄清一下,“进程池”是一组在channel上等待工作的workergoroutines。它们应该在工作到达时启动/停止,还是在程序启动时启动并等待工

python - 相当于golang中的itemgetter

我正在将一个程序从python转换为golang,我有一行获取嵌套列表中的第一个值:x_values=map(operator.itemgetter(0),self.coords)此命令将[[1,2],[2,3],[7,4]]转换为[1,2,7]。在go中有类似的东西吗? 最佳答案 Go中的等价物是for循环:packagemainimport("fmt")funcmain(){a:=make([][]int,3)a[0]=[]int{1,2}a[1]=[]int{2,3}a[2]=[]int{7,4}b:=make([]int,l

go - 有没有我们会求助于进程而不是 goroutine 的情况?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我知道goroutine的重量很轻,我们可以生成数千个goroutine,但我想知道在某些情况下我们应该生成一个进程而不是goroutine(比如在资源方面达到某种进程边界或者是其他东西)。在某些情况下生成新进程是否有利于资源利用或其他方面?

go - 同一网络中的应用程序和服务器之间的通信

关闭。这个问题需要更多focused.它目前不接受答案。想改进这个问题吗?更新问题,使其只关注一个问题editingthispost.关闭3年前。Improvethisquestion我正在开发将在kubernetes上运行的CI/CD工具。该应用程序将负责创建一个k8s作业对象,该对象将被视为一个slave以运行管道。图像,slave将运行完全取决于用户,所以我无法控制它,除了它会在与CI/CD应用程序相同的本地网络中运行。我的问题是;在这种情况下,如何使CI/CD工具与从属之间进行通信?为了为此添加更多上下文,我想创建类似于Jenkins的东西。Jenkins与kubernetes

根据python在Excel中的某些列中删除重复行

importpandasaspdtoclean=pd.ExcelFile(r'C:\Users\Desktop\NewMicrosoftExcelWorksheet.xlsx',sheetname=0)df4=toclean.drop_duplicates(subset='A',keep='last')df4.save(r'C:\Users\Desktop\final.xlsx')我在Excel中有一些信息,可以说名称DIADADFA32323221122321现在我的输出应该看起来像3232322111看答案以外df4.save(r'c:\users\desktop\final.xlsx')