根据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脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

Python实现自动化Word文档样式复制与内容生成

《Python实现自动化Word文档样式复制与内容生成》在办公自动化领域,高效处理Word文档的样式和内容复制是一个常见需求,本文将展示如何利用Python的python-docx库实现... 目录一、为什么需要自动化 Word 文档处理二、核心功能实现:样式与表格的深度复制1. 表格复制(含样式与内容)2

python如何生成指定文件大小

《python如何生成指定文件大小》:本文主要介绍python如何生成指定文件大小的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python生成指定文件大小方法一(速度最快)方法二(中等速度)方法三(生成可读文本文件–较慢)方法四(使用内存映射高效生成

Maven项目中集成数据库文档生成工具的操作步骤

《Maven项目中集成数据库文档生成工具的操作步骤》在Maven项目中,可以通过集成数据库文档生成工具来自动生成数据库文档,本文为大家整理了使用screw-maven-plugin(推荐)的完... 目录1. 添加插件配置到 pom.XML2. 配置数据库信息3. 执行生成命令4. 高级配置选项5. 注意事

mybatis的mapper对应的xml写法及配置详解

《mybatis的mapper对应的xml写法及配置详解》这篇文章给大家介绍mybatis的mapper对应的xml写法及配置详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录前置mapper 对应 XML 基础配置mapper 对应 xml 复杂配置Mapper 中的相

MybatisX快速生成增删改查的方法示例

《MybatisX快速生成增删改查的方法示例》MybatisX是基于IDEA的MyBatis/MyBatis-Plus开发插件,本文主要介绍了MybatisX快速生成增删改查的方法示例,文中通过示例代... 目录1 安装2 基本功能2.1 XML跳转2.2 代码生成2.2.1 生成.xml中的sql语句头2

Golang实现Redis分布式锁(Lua脚本+可重入+自动续期)

《Golang实现Redis分布式锁(Lua脚本+可重入+自动续期)》本文主要介绍了Golang分布式锁实现,采用Redis+Lua脚本确保原子性,持可重入和自动续期,用于防止超卖及重复下单,具有一定... 目录1 概念应用场景分布式锁必备特性2 思路分析宕机与过期防止误删keyLua保证原子性可重入锁自动

java中XML的使用全过程

《java中XML的使用全过程》:本文主要介绍java中XML的使用全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录什么是XML特点XML作用XML的编写语法基本语法特殊字符编写约束XML的书写格式DTD文档schema文档解析XML的方法​​DOM解析XM

MySQL Workbench工具导出导入数据库方式

《MySQLWorkbench工具导出导入数据库方式》:本文主要介绍MySQLWorkbench工具导出导入数据库方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录mysql Workbench工具导出导入数据库第一步 www.chinasem.cn数据库导出第二步