python xml第三方库_使用python xml库将XML转换为csv

抱歉,是否已经问过这个问题。

我在下面的XML文件中想要将其转换为CSV或Excel。

在这里,我想提取IpRoutelist下的NodeName及其子DestIPAddress。

<?xml version="1.0" encoding="utf-8"?>

OK

OK

IMUMB0899

IMUMB0899

1000 SFP

TT

DND

DND

0

Enabled

Macro

397063

120

172.172.6.20

255.255.255.255

172.21.200.1

2405:20:1::

40

2405:20:101:4:7:2:61:1

我尝试下面的代码提取名称和IProute,但是当我尝试合并tham时,只有一个IP路由针对NodeName,但是有两个可用。

from bs4 import BeautifulSoup

import pandas as pd

import lxml

import xml.etree.cElementTree

import openpyxl

import inspect

import os

sites = "xml"

with open(sites, "r",encoding='unicode_escape') as f:

xml_data = f.read()

soup = BeautifulSoup(xml_data, "xml")

tag1 = input("Enter tagname1:")

tag2 = input("Enter tagname2:")

data = []

dd = []

for td in soup.find_all(tag1):

data.append({"NodeName": td.text})

for iproute in soup.find_all(tag2):

dd.append({"IpRoute": iproute.text})

df1 = pd.DataFrame(data)

df2 = pd.DataFrame(dd)

df = pd.merge(df1,df2,left_index=True, right_index=True)

df.to_excel(sites + '.xlsx', sheet_name='Detail', index = False)

print("*************Done*************")

Expected Output:

7185

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值