我正在尝试使用 openshift python 库获取项目中 configmap 的数据。我设法获取了 configmap 的名称,但我可以在文档中找到用于提取数据的函数或示例。有没有人遇到过这个问题或者知道如何做到这一点?
这是我用来获取 cm 名称的代码(返回一个字典):
import openshift as oc if __name__ == '__main__': project_selector = oc.selector('projects') projects = project_selector.objects() number_of_projects = len(projects) for project in projects: name = project.model.metadata.name oc.invoke('project', name) tokens = oc.invoke('get', ['configmaps']).actions()[0].as_dict()['out'].replace('\n', ' ').split(' ') configmap_data = [x for x in tokens if len(x) > 0 and not x.isupper()] print(configmap_data)
我确实尝试使用 oc.selector
并使用 with oc.selector(project_name):
来尝试获取一些数据,但找不到获取它的方法。
请注意,我不需要使用 oc cmd 命令,而必须使用 python。 目前我只需要数据,稍后看看如何更改它。
谢谢。
正确答案
如果您使用 oc.invoke
,则需要传递适当的命令行参数。考虑一下如果手动运行相同的命令会发生什么:
$ oc get configmaps name data age coredns 1 54d extension-apiserver-authentication 6 54d kube-apiserver-legacy-service-account-token-tracking 1 54d kube-proxy 2 54d kube-root-ca.crt 1 54d kubeadm-config 1 54d kubelet-config 1 54d
您得到了名称,但没有得到内容。如果你想要内容,则需要选择更合适的输出格式,例如 -o json
:
$ oc get configmaps kubelet-config -o json { "apiversion": "v1", "data": { ... }, "kind": "configmap", "metadata": { "name": "kubelet-config", "namespace": "kube-system", } }
您需要在对 oc.invoke
的调用中包含相同的参数。像这样的东西演示了事情是如何工作的:
import openshift as oc import json project_selector = oc.selector('projects') projects = project_selector.objects() for project in projects: # get a list of configmap names configmaps = oc.invoke('get', ['-n', project.name(), '-o', 'name', 'configmaps']) # for each configmap, get the content for cm in configmaps.out().splitlines(): out = oc.invoke('get', ['-n', project.name(), '-o', 'json', cm]) manifest = json.loads(out.out()) data = manifest['data'] print(data)
这可行,但不要这样做。
很明显您已经知道如何使用选择器,因为这就是您迭代项目的方式。您应该使用相同的技术来迭代配置映射:
import openshift as oc projects = oc.selector('projects') for project in projects.objects(): with oc.project(project.name()): configmaps = oc.selector('configmaps') for cm in configmaps.objects(): data = cm.as_dict()['data'] print(data)
这很大程度上基于示例 straight from the documentation。迭代 configmaps.objects()
可为每个 configmap 获取一个 api 对象。您可以访问该名称和内容。
以上是使用 python 获取 Openshift ConfigMap 数据的详细内容。更多信息请关注PHP中文网其他相关文章!

本教程演示如何使用Python处理Zipf定律这一统计概念,并展示Python在处理该定律时读取和排序大型文本文件的效率。 您可能想知道Zipf分布这个术语是什么意思。要理解这个术语,我们首先需要定义Zipf定律。别担心,我会尽量简化说明。 Zipf定律 Zipf定律简单来说就是:在一个大型自然语言语料库中,最频繁出现的词的出现频率大约是第二频繁词的两倍,是第三频繁词的三倍,是第四频繁词的四倍,以此类推。 让我们来看一个例子。如果您查看美国英语的Brown语料库,您会注意到最频繁出现的词是“th

本文解释了如何使用美丽的汤库来解析html。 它详细介绍了常见方法,例如find(),find_all(),select()和get_text(),以用于数据提取,处理不同的HTML结构和错误以及替代方案(SEL)

处理嘈杂的图像是一个常见的问题,尤其是手机或低分辨率摄像头照片。 本教程使用OpenCV探索Python中的图像过滤技术来解决此问题。 图像过滤:功能强大的工具 图像过滤器

本文比较了Tensorflow和Pytorch的深度学习。 它详细介绍了所涉及的步骤:数据准备,模型构建,培训,评估和部署。 框架之间的关键差异,特别是关于计算刻度的

Python是数据科学和处理的最爱,为高性能计算提供了丰富的生态系统。但是,Python中的并行编程提出了独特的挑战。本教程探讨了这些挑战,重点是全球解释

本教程演示了在Python 3中创建自定义管道数据结构,利用类和操作员超载以增强功能。 管道的灵活性在于它能够将一系列函数应用于数据集的能力,GE

Python 对象的序列化和反序列化是任何非平凡程序的关键方面。如果您将某些内容保存到 Python 文件中,如果您读取配置文件,或者如果您响应 HTTP 请求,您都会进行对象序列化和反序列化。 从某种意义上说,序列化和反序列化是世界上最无聊的事情。谁会在乎所有这些格式和协议?您想持久化或流式传输一些 Python 对象,并在以后完整地取回它们。 这是一种在概念层面上看待世界的好方法。但是,在实际层面上,您选择的序列化方案、格式或协议可能会决定程序运行的速度、安全性、维护状态的自由度以及与其他系

Python的statistics模块提供强大的数据统计分析功能,帮助我们快速理解数据整体特征,例如生物统计学和商业分析等领域。无需逐个查看数据点,只需查看均值或方差等统计量,即可发现原始数据中可能被忽略的趋势和特征,并更轻松、有效地比较大型数据集。 本教程将介绍如何计算平均值和衡量数据集的离散程度。除非另有说明,本模块中的所有函数都支持使用mean()函数计算平均值,而非简单的求和平均。 也可使用浮点数。 import random import statistics from fracti


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

Dreamweaver Mac版
视觉化网页开发工具

Atom编辑器mac版下载
最流行的的开源编辑器

禅工作室 13.0.1
功能强大的PHP集成开发环境