- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
大家早上好
这次我不是提出一个特定的代码问题,而是提出一个“我是否走在正确的轨道上”的问题。
我想编写一个用于暂存网络设备的脚本。我将得到一个包含两列的 cvs 列表:主机名 + 硬件类型,例如:
Hostname,Type
TestAP-1,AP250
TestAP-2,AP250
TestAP-3,AP250
TestSW-1,SW100
TestSW-2,SW100
TestAP-4,AP250
真正的列表显然会更长。
到目前为止,我的想法是解析调用硬件类型脚本的参数以获取主机名列表。然后连接到硬件(IP 地址将始终是相同的默认 IP 或通过串行控制台),向硬件发送一些命令(设置主机名、系统日志服务器 ip 等),再次从机器读取值(使用 show 命令) )并将结果写入另一个 csv 文件。
类似于:
staging.py AP250
get a list with all hostnames where the HW Type is AP250
loop
connect (ssh or serial) to the hardware
commands:
set hostname 'hostname'
set syslog ip (fixed ip address, the same for all devices)
set whatever need to be set as well
the do a show on these settings and parse the value
write the value to a output csv file (create or append)
我走在正确的道路上吗?现在,我的脚本如下所示:
import csv
import argparse
parser = argparse.ArgumentParser()
parser.add_argument('Type', type=str,
help='REQUIRED: Please enter the Hardware Type (AP250, SW100, etc)')
args = parser.parse_args()
Manager = "manager.domain.com"
MACAddress = "aa:bb:cc:dd:ee:ff"
with open("input.csv", 'r', newline='') as f:
reader = csv.DictReader(f)
for row in reader:
if row['Type'] == args.Type:
print(row['Hostname']) # This will later on be replaced by some paramiko code
h = (row['Hostname'])
t = (row['Type'])
outdict = {}
print (outdict)
"""
with open('output.csv', 'w', newline='') as o:
writer = csv.DictWriter(o, delimiter=',', fieldnames=["Hostname", "Type", "Hivemanager", "MACAddress"])
writer.writeheader()
newrow = (h + "," + t + "," + Manager + "," + MACAddress)
writer.writerow(newrow)
#writer.writerows(['Hostname'], ['Type'], Manager)
print (open('output.csv', 'r').read())
"""
input("Press Enter to continue")
我不确定的地方:
我不期望完全工作的脚本作为答案。相反,一些可以让我获得一些想法的提示或链接会很棒。
非常感谢。
最佳答案
至于你的第一个问题,使用字典是否正确,答案是双重的。首先,如果您的目标是 csv
阅读器,那么绝对是。这是正确的做法。您以 CSV 格式获取输入数据,因此没有明智的方法来解决 csv.DictReader
问题。其次,输出部分;这是您要存储返回值的位置。为此,您不一定需要字典,在我看来,列表会更容易。您计划使用 outdict
来实现此目的,对吗?但这又是个人喜好的问题,字典也可以,只是对数据的访问有点不同。底线是:是的,对于第一个问题,您的思路是正确的。
除了循环主机名并在每个主机名的基础上执行所有操作之外,还有什么(明智的)替代方案?这最大限度地减少了您必须对各个主机执行的登录操作,如果您在脚本中间失去网络连接,您只需修复一台主机,而不是所有主机。
希望这对您有帮助。
关于python - 出于暂存目的循环遍历 CSV 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35813383/
我正在处理一组标记为 160 个组的 173k 点。我想通过合并最接近的(到 9 或 10 个组)来减少组/集群的数量。我搜索过 sklearn 或类似的库,但没有成功。 我猜它只是通过 knn 聚类
我有一个扁平数字列表,这些数字逻辑上以 3 为一组,其中每个三元组是 (number, __ignored, flag[0 or 1]),例如: [7,56,1, 8,0,0, 2,0,0, 6,1,
我正在使用 pipenv 来管理我的包。我想编写一个 python 脚本来调用另一个使用不同虚拟环境(VE)的 python 脚本。 如何运行使用 VE1 的 python 脚本 1 并调用另一个 p
假设我有一个文件 script.py 位于 path = "foo/bar/script.py"。我正在寻找一种在 Python 中通过函数 execute_script() 从我的主要 Python
这听起来像是谜语或笑话,但实际上我还没有找到这个问题的答案。 问题到底是什么? 我想运行 2 个脚本。在第一个脚本中,我调用另一个脚本,但我希望它们继续并行,而不是在两个单独的线程中。主要是我不希望第
我有一个带有 python 2.5.5 的软件。我想发送一个命令,该命令将在 python 2.7.5 中启动一个脚本,然后继续执行该脚本。 我试过用 #!python2.7.5 和http://re
我在 python 命令行(使用 python 2.7)中,并尝试运行 Python 脚本。我的操作系统是 Windows 7。我已将我的目录设置为包含我所有脚本的文件夹,使用: os.chdir("
剧透:部分解决(见最后)。 以下是使用 Python 嵌入的代码示例: #include int main(int argc, char** argv) { Py_SetPythonHome
假设我有以下列表,对应于及时的股票价格: prices = [1, 3, 7, 10, 9, 8, 5, 3, 6, 8, 12, 9, 6, 10, 13, 8, 4, 11] 我想确定以下总体上最
所以我试图在选择某个单选按钮时更改此框架的背景。 我的框架位于一个类中,并且单选按钮的功能位于该类之外。 (这样我就可以在所有其他框架上调用它们。) 问题是每当我选择单选按钮时都会出现以下错误: co
我正在尝试将字符串与 python 中的正则表达式进行比较,如下所示, #!/usr/bin/env python3 import re str1 = "Expecting property name
考虑以下原型(prototype) Boost.Python 模块,该模块从单独的 C++ 头文件中引入类“D”。 /* file: a/b.cpp */ BOOST_PYTHON_MODULE(c)
如何编写一个程序来“识别函数调用的行号?” python 检查模块提供了定位行号的选项,但是, def di(): return inspect.currentframe().f_back.f_l
我已经使用 macports 安装了 Python 2.7,并且由于我的 $PATH 变量,这就是我输入 $ python 时得到的变量。然而,virtualenv 默认使用 Python 2.6,除
我只想问如何加快 python 上的 re.search 速度。 我有一个很长的字符串行,长度为 176861(即带有一些符号的字母数字字符),我使用此函数测试了该行以进行研究: def getExe
list1= [u'%app%%General%%Council%', u'%people%', u'%people%%Regional%%Council%%Mandate%', u'%ppp%%Ge
这个问题在这里已经有了答案: Is it Pythonic to use list comprehensions for just side effects? (7 个答案) 关闭 4 个月前。 告
我想用 Python 将两个列表组合成一个列表,方法如下: a = [1,1,1,2,2,2,3,3,3,3] b= ["Sun", "is", "bright", "June","and" ,"Ju
我正在运行带有最新 Boost 发行版 (1.55.0) 的 Mac OS X 10.8.4 (Darwin 12.4.0)。我正在按照说明 here构建包含在我的发行版中的教程 Boost-Pyth
学习 Python,我正在尝试制作一个没有任何第 3 方库的网络抓取工具,这样过程对我来说并没有简化,而且我知道我在做什么。我浏览了一些在线资源,但所有这些都让我对某些事情感到困惑。 html 看起来
我是一名优秀的程序员,十分优秀!