首页 > 编程问答 >如何使用“pyroute2”“添加”通过“get”接收的路由?

如何使用“pyroute2”“添加”通过“get”接收的路由?

时间:2024-08-01 05:02:44浏览次数:13  
标签:python iproute pyroute2

不幸的是, pyroute2 模块的文档相当具体,所以我找不到我遇到的一个特定问题的答案。 我的目标是保存一个特定表(让我们将其命名为表 A )中的所有路由,然后恢复它们。我可以(显然)接收路由转储并使用单个命令清除表: IPRoute().flush_routes(table=A) 路线存储为字典元组。显然我想用 IPRoute().route("add", table=A, ...) 恢复它们,但是参数应该是什么?

我理想的代码应该是这样的:

routes_dump = IPRoute().flush_routes(table=A)
# some processing (while table A has no routes in it)...
for route in routes_dump:
    IPRoute().route("add", table=A, ...)

如果有任何关于它是如何的想法,我将不胜感激可行的!


你可以使用 pyroute2 中的 get() 函数检索的相同字典来添加路由。 pyroute2 route() 函数可以接受一个字典作为参数,该字典包含要添加路由的属性。

以下是操作方法:

from pyroute2 import IPRoute

# 定义表 ID
TABLE_A = 254  # 或者的表的名称

# 创建一个 IPRoute 对象
ip = IPRoute()

# 获取表 A 中的路由
routes_dump = ip.get_routes(table=TABLE_A)

# 清除表 A 中的路由
ip.route("flush", table=TABLE_A)

# 对路由执行一些处理...

# 将路由添加回表 A
for route in routes_dump:
    # 从路由字典中移除 'table' 属性,因为它已经在 'route()' 函数中指定了
    route.pop('table', None) 
    ip.route("add", **route)

# 关闭 IPRoute 对象
ip.close()

说明:

  1. 我们首先使用 get_routes(table=TABLE_A) 获取表 A 中的所有路由。这将返回一个字典列表,其中每个字典代表一个路由。
  2. 然后,我们使用 route("flush", table=TABLE_A) 清除表 A 中的路由。
  3. 在对路由执行必要的处理后,我们遍历 routes_dump 中的每个路由,并使用 route("add", **route) 将其添加回表 A。
  4. route("add", **route) 语句中,我们使用 ** 运算符将路由字典解包为关键字参数。这会将路由的属性传递给 route() 函数。
  5. 我们从 route 字典中删除了 'table' 属性,因为它已经在 route() 函数中作为参数传递。

这样就可以保存和恢复特定路由表中的路由。

标签:python,iproute,pyroute2
From: 78818316

相关文章

  • Python 将脚本转换为 exe 并给出 PermissionError
    我有一个Python(Windows10)脚本,其功能之一是创建备份。这是函数:defcreate_backups(self,file:str,counter:int=None)->None:counter=counteror1res=self.re_obj.match(file)ifresisNoneorlen(res.groups())==0:back_file=......
  • conda update python 不会更新,但 conda update --all 会更新
    我正在尝试更新我的venv。这就是我看到的(base_test)>condaupdatepythonCollectingpackagemetadata(current_repodata.json):doneSolvingenvironment:done==>WARNING:Anewerversionofcondaexists.<==currentversion:4.10.3latestversion:24......
  • 如何使用 Selenium (python) 访问另一个影子根中影子根中的元素?
    我有以下代码和HTML结构(我不是这方面的专家)。我正在尝试抓取HTML代码末尾的96.00C元素,其路径是:Xpath://*[@id="_grid"]/set-class2/div2/text-binding//text()完整Xpath:/html/body/main/div/div3/div3/......
  • 在Python中,如何在一段时间内接受输入
    我正在尝试用Python制作一个蛇游戏,但不知道如何制作它,以便蛇在没有玩家输入的情况下继续移动,所以如果有人知道一个简单的方法来做到这一点,我需要在2秒后取消输入将不胜感激代码如下:importrandomimportsysplayerY=(1)playerX=(0)appleY=random.randint(1,10)appl......
  • 在Python中单步执行代码时是否可以引发异常
    当我在IDE(例如PyCharm)中单步执行代码时,我想转储函数的参数(以供以后使用,例如复制它)。计划的场景是在某处设置断点,然后引发异常(这不在我运行的代码中,这就是重点),并捕获它。代码应该如下所示:defexception_cathcher_decorator(func):try:returnfunc(*f_args,**f_k......
  • 解决python自动化操作异常处理的问题
    在python自动化领域,往往要用到pyautogui,pywin32等模块实现自动化操作。然而,这种自动化操作,本身具有一定的局限性,其中最主要的一个问题就是,一旦执行结果不按照脚本预设的来执行,往往会抛出异常,导致程序中断。解决这个问题,主要有这么几种思路:第一,每一次操作后分情况讨论。这种方......
  • Python爬虫入门03:用Urllib假装我们是浏览器
    文章目录引言Urllib库简介Request模块详解Error模块与异常处理Parse模块与URL解析Robotparser模块模拟浏览器请求使用Request方法添加请求头信息代码示例1.设置请求URL和请求头2.定义请求参数并转换为适当的格式3.使用Request方法封装请求4.发送请求并获取响应常用......
  • 请以零基础学Python 之 第二十讲 分组和贪婪匹配
    当我们处理字符串时,有时候需要根据特定的模式来分割或者提取信息。Python提供了强大的正则表达式库re,可以帮助我们实现这些复杂的字符串操作。本篇博客将介绍两个常用的正则表达式技巧:分组和贪婪匹配。分组(Grouping)在正则表达式中,分组是将多个模式单元组合为一个单元,以便......
  • 零基础学python 之 第十九讲 正则表达式
    当你开始学习Python编程时,正则表达式是一项非常强大的工具,用于处理文本数据中的模式匹配和搜索。本篇博客将带你从零开始学习如何在Python中使用正则表达式。1.什么是正则表达式?正则表达式(RegularExpression)是用于描述字符串模式的一种工具,可以用来匹配、查找、替换符合特......
  • python之贪吃蛇
    废话不多说,直接上代码(确保已经安装pygame)importpygameimportrandom#基础设置#屏幕高度SCREEN_HEIGHT=480#屏幕宽度SCREEN_WIDTH=600#小方格大小GRID_SIZE=20#颜色设置WHITE=(255,255,255)BLACK=(0,0,0)GREEN=(0,255,0)#初始化Pyg......