根据TR069数据模型xml文件生成用于XACS中可用于导入的脚本

2024-02-04 20:08

本文主要是介绍根据TR069数据模型xml文件生成用于XACS中可用于导入的脚本,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

#! /usr/bin/env python
#coding=utf-8
'''
本脚本用于将xml格式数据模型转换成可用于xacs导入格式的文件
Python 版本 2.7
lxml  https://pypi.python.org/pypi/lxml/3.2.5
该脚本不支持base的方式import,尽量使用full类型xml
contact : 402245352#qq.com
'''import sys
import copy
from lxml import etreeclass syx_any(object):def __init__(self, ele) :self.type = 'any'class syx_base64(object):def __init__(self, ele) :self.type = 'base64'for sub in ele:if sub.tag == 'size':self.size = size_e(sub)class syx_boolean(object):def __init__(self, ele):self.type='boolean'class syx_dateTime(object):def __init__(self, ele):self.type='dateTime'class syx_hexBinary(object):def __init__(self,ele):self.type = 'hexBinary'for sub in ele:if sub.tag == 'size':self.size = size_e(sub)class syx_int(object):def __init__(self, ele) :self.type = 'int'self.ranges = []self.units = Nonefor sub in ele :if sub.tag == 'range':r = range_e(sub)self.ranges.append(r)elif sub.tag =='units' :self.units = units_e(sub)class syx_integer(object):def __init__(self, ele) :self.type = 'integer'self.ranges = []self.units = Nonefor sub in ele :if sub.tag == 'range':r = range_e(sub)self.ranges.append(r)elif sub.tag =='units' :self.units = units_e(sub)class syx_long(object):def __init__(self, ele) :self.type = 'long'self.ranges = []self.units = Nonefor sub in ele :if sub.tag == 'range':r = range_e(sub)self.ranges.append(r)elif sub.tag =='units' :self.units = units_e(sub)class syx_unsignedInt(object):def __init__(self, ele) :self.type = 'unsignedInt'self.ranges = []self.units = Nonefor sub in ele :if sub.tag == 'range':r = range_e(sub)self.ranges.append(r)elif sub.tag =='units' :self.units = units_e(sub)class syx_unsignedLong(object):def __init__(self, ele) :self.type = 'unsignedLong'self.ranges = []self.units = Nonefor sub in ele :if sub.tag == 'range':r = range_e(sub)self.ranges.append(r)elif sub.tag =='units' :self.units = units_e(sub)class syx_string(object):def __init__(self, ele) :self.type = 'string'self.enumerations = []self.patterns = []self.size = Nonefor sub in ele :if sub.tag == 'size' :self.size = size_e(sub)elif sub.tag == 'enumeration' :e = enumeration_e(sub)self.enumerations.append(e)elif sub.tag == 'pattern' :p = pattern_e(sub)self.patterns.append(p)elif sub.tag == 'pathRef':continueelif sub.tag == 'enumerationRef':self.enumerationRef = enumerationRef_e(sub)'''
<enumerationRef targetParam="AllowedProfiles" nullValue=""/>
'''
class enumerationRef_e(object):def __init__(self, ele):self.targetParam = ele.get('targetParam')self.nullValue = ele.get('nullValue')class pattern_e(object):def __init__(self, ele) :self.value = ele.get('value')class enumeration_e(object):def __init__(self,ele):self.value = ele.get('value')self.optional = ele.get('optional')class range_e(object):def __init__(self,ele):self.minInclusive = ele.get('minInclusive')self.maxInclusive = ele.get('maxInclusive')self.step = ele.get('step')class size_e(object):def __init__(self, ele):self.minLength = ele.get('minLength')self.maxLength = ele.get('maxLength')class units_e(object):def __init__(self, ele):self.value = ele.get('value')class dimport (object):def __init__(self, node):self.tag = 'import'self.file = node.get('file')if 'types' in self.file :print 'load types define file %s ' % self.filetypesTree = etree.parse(self.file)root = typesTree.getroot()for item in root :#print 'type item tag %s ' % item.tagif 'dataType' == item.tag :name = item.get('name')base = item.get('base')if base != None :if base in importTypes :obj_syntax = copy.deepcopy(importTypes[base])obj = syntax.syxclazz = importTypes[base].__class__for sub in item:if sub.tag == 'size' :s = size_e(sub)setattr(obj, 'size', s)elif sub.tag == 'pattern':p = pattern_e(sub)getattr(obj , 'patterns').append(p)importTypes[name] = obj_syntaxelse:raise 'load types error , no base type %s for %s' % (base, name)else:syntax = dsyntax(item)importTypes[name] = syntaxclass dmodel(object):def __init__(self, node):self.tag = 'model'self.name = node.get('name')self.objs = []for obj in node :if obj.tag == 'object' :oj = dobject(obj)self.objs.append(oj)if obj.tag == 'parameter' :param = dparam(obj)self.objs.append(param)class dobject(object):def __init__(self, node):self.tag = 'object'self.name = node.get('name')self.access = node.get('access')self.minEntries = node.get('minEntries')self.maxEntries = node.get('maxEntries')self.numEntriesParameter = node.get('numEntriesParameter')self.parameters = []self.description = ''for item  in node:if item.tag == 'description' :self.description = item.textelif item.tag == 'parameter':p = dparam(item)self.parameters.append(p)def getLine(self):displayName = self.nameif displayName.find('InternetGatewayDevice') >= 0:displayName = self.name[split:]type = 'object'length = ''min = ''max = ''access = '-'if self.access == 'readWrite':access = 'W'default = ''version = ''descr = self.descriptionline =  pattern % (displayName, type, length, min, max, access, default, version, oneline(descr))line = line.encode('utf-8','ignore')return lineclass dparam (object):def __init__(self, node):self.tag = 'parameter'self.name = node.get('name')self.access = node.get('access')if node.get('dmr:version') != None :self.version = node.get('dmr:version')else:self.version = '1.0'for item in node :if item.tag == 'description' :self.description = item.textif item.tag == 'syntax':self.synax = dsyntax(item)def getLine(self, parentName = ''):length = ''min = ''max = ''default = ''version = self.version  displayName = (obj.name + self.name)if displayName.find('InternetGatewayDevice') >= 0 :displayName = displayName[split:]access = '-'if self.access == 'readWrite':access = 'W'descr = self.descriptiontype = self.synax.type#print '----------------name : %s ' % param.name#print param.synax.syxif type in ('base64', 'hexBinary', 'string') :if self.synax.syx.size != None:if self.synax.syx.size.minLength != None:min = self.synax.syx.size.minLengthif self.synax.syx.size.maxLength != None:max = self.synax.syx.size.maxLengthline = pattern % (displayName, type, length, min, max, access, default, version, oneline(descr))line = line.encode('utf-8','ignore')#fileline.append(line + '\n')#print linereturn linebuildInTypes=['any','base64','boolean','dateTime','hexBinary','integer','int','long','string','unsignedInt','unsignedLong']
importTypes={}#名称	类型	长度	最小值	最大值	读写类型(W或-)	默认值	版本	描述
pattern = '%s\t%s\t%s\t%s\t%s\t%s\t%s\t%s\t%s'split = len('InternetGatewayDevice')class dsyntax(object):def __init__(self, node):for item  in node:# xs:enumeration value="*"#if item.tag == 'list':  #list transfer to string#    item.tag = 'string'if item.tag in buildInTypes:self.type = item.tagclassName = 'syx_'+item.tagcurrentModule=sys.modules[__name__]clazz = getattr(currentModule, className)obj = clazz(item)self.syx = objelif item.tag == 'dataType':exType = item.get('ref')sx = importTypes[exType]self.syx = sx.syxself.type = self.syx.typepassmodel = None
imports = []def oneline(str):return str.replace('\n' , '')if __name__ == '__main__' :if len(sys.argv) < 2 :print 'Usage: python p.py fileName'sys.exit()tree = etree.parse(sys.argv[1])
#    tree = etree.parse('tr-135-1-3-full.xml') root = tree.getroot()for item in root:if item.tag == 'model':model = dmodel(item)elif item.tag == 'import':imt = dimport(item)imports.append(imt)elif item.tag == 'dataType':name = item.get('name')base = item.get('base')if base != None :if base in importTypes :obj_syntax = copy.deepcopy(importTypes[base])obj = syntax.syxclazz = importTypes[base].__class__for sub in item:if sub.tag == 'size' :s = size_e(sub)setattr(obj, 'size', s)elif sub.tag == 'pattern':p = pattern_e(sub)getattr(obj , 'patterns').append(p)importTypes[name] = obj_syntaxelse:raise 'load types error , no base type %s for %s' % (base, name)else:syntax = dsyntax(item)importTypes[name] = syntaxnewFileName = sys.argv[1] + '.out.txt'file = open(newFileName, 'wb')for obj in model.objs:print 'Export first level %s ' % obj.nameif obj.tag == 'parameter':line = obj.getLine()file.write(line + '\n')#print lineelif obj.tag == 'object':line = obj.getLine()file.write(line + '\n')for param in obj.parameters:line = param.getLine(obj.name)#print linefile.write(line + '\n')#file.writelines(fileline)            file.close()     print ''   print 'Export OK , see %s ' % newFileName     

这篇关于根据TR069数据模型xml文件生成用于XACS中可用于导入的脚本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/678669

相关文章

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

oracle 11g导入\导出(expdp impdp)之导入过程

《oracle11g导入导出(expdpimpdp)之导入过程》导出需使用SEC.DMP格式,无分号;建立expdir目录(E:/exp)并确保存在;导入在cmd下执行,需sys用户权限;若需修... 目录准备文件导入(impdp)1、建立directory2、导入语句 3、更改密码总结上一个环节,我们讲了

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

Java调用Python脚本实现HelloWorld的示例详解

《Java调用Python脚本实现HelloWorld的示例详解》作为程序员,我们经常会遇到需要在Java项目中调用Python脚本的场景,下面我们来看看如何从基础到进阶,一步步实现Java与Pyth... 目录一、环境准备二、基础调用:使用 Runtime.exec()2.1 实现步骤2.2 代码解析三、

Python脚本轻松实现检测麦克风功能

《Python脚本轻松实现检测麦克风功能》在进行音频处理或开发需要使用麦克风的应用程序时,确保麦克风功能正常是非常重要的,本文将介绍一个简单的Python脚本,能够帮助我们检测本地麦克风的功能,需要的... 目录轻松检测麦克风功能脚本介绍一、python环境准备二、代码解析三、使用方法四、知识扩展轻松检测麦

C#使用Spire.XLS快速生成多表格Excel文件

《C#使用Spire.XLS快速生成多表格Excel文件》在日常开发中,我们经常需要将业务数据导出为结构清晰的Excel文件,本文将手把手教你使用Spire.XLS这个强大的.NET组件,只需几行C#... 目录一、Spire.XLS核心优势清单1.1 性能碾压:从3秒到0.5秒的质变1.2 批量操作的优雅

Python使用python-pptx自动化操作和生成PPT

《Python使用python-pptx自动化操作和生成PPT》这篇文章主要为大家详细介绍了如何使用python-pptx库实现PPT自动化,并提供实用的代码示例和应用场景,感兴趣的小伙伴可以跟随小编... 目录使用python-pptx操作PPT文档安装python-pptx基础概念创建新的PPT文档查看

Java实现TXT文件导入功能的详细步骤

《Java实现TXT文件导入功能的详细步骤》在实际开发中,很多应用场景需要将用户上传的TXT文件进行解析,并将文件中的数据导入到数据库或其他存储系统中,本文将演示如何用Java实现一个基本的TXT文件... 目录前言1. 项目需求分析2. 示例文件格式3. 实现步骤3.1. 准备数据库(假设使用 mysql

在ASP.NET项目中如何使用C#生成二维码

《在ASP.NET项目中如何使用C#生成二维码》二维码(QRCode)已广泛应用于网址分享,支付链接等场景,本文将以ASP.NET为示例,演示如何实现输入文本/URL,生成二维码,在线显示与下载的完整... 目录创建前端页面(Index.cshtml)后端二维码生成逻辑(Index.cshtml.cs)总结