根据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

相关文章

C#中读取XML文件的四种常用方法

《C#中读取XML文件的四种常用方法》Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具,下面我们就来看看C#中读取XML文件的方法都有哪些吧... 目录XML简介格式C#读取XML文件方法使用XmlDocument使用XmlTextReader/XmlTextWr

浅析如何使用Swagger生成带权限控制的API文档

《浅析如何使用Swagger生成带权限控制的API文档》当涉及到权限控制时,如何生成既安全又详细的API文档就成了一个关键问题,所以这篇文章小编就来和大家好好聊聊如何用Swagger来生成带有... 目录准备工作配置 Swagger权限控制给 API 加上权限注解查看文档注意事项在咱们的开发工作里,API

Java使用POI-TL和JFreeChart动态生成Word报告

《Java使用POI-TL和JFreeChart动态生成Word报告》本文介绍了使用POI-TL和JFreeChart生成包含动态数据和图表的Word报告的方法,并分享了实际开发中的踩坑经验,通过代码... 目录前言一、需求背景二、方案分析三、 POI-TL + JFreeChart 实现3.1 Maven

10个Python自动化办公的脚本分享

《10个Python自动化办公的脚本分享》在日常办公中,我们常常会被繁琐、重复的任务占据大量时间,本文为大家分享了10个实用的Python自动化办公案例及源码,希望对大家有所帮助... 目录1. 批量处理 Excel 文件2. 自动发送邮件3. 批量重命名文件4. 数据清洗5. 生成 PPT6. 自动化测试

使用Java实现一个解析CURL脚本小工具

《使用Java实现一个解析CURL脚本小工具》文章介绍了如何使用Java实现一个解析CURL脚本的工具,该工具可以将CURL脚本中的Header解析为KVMap结构,获取URL路径、请求类型,解析UR... 目录使用示例实现原理具体实现CurlParserUtilCurlEntityICurlHandler

10个Python Excel自动化脚本分享

《10个PythonExcel自动化脚本分享》在数据处理和分析的过程中,Excel文件是我们日常工作中常见的格式,本文将分享10个实用的Excel自动化脚本,希望可以帮助大家更轻松地掌握这些技能... 目录1. Excel单元格批量填充2. 设置行高与列宽3. 根据条件删除行4. 创建新的Excel工作表5

Linux中shell解析脚本的通配符、元字符、转义符说明

《Linux中shell解析脚本的通配符、元字符、转义符说明》:本文主要介绍shell通配符、元字符、转义符以及shell解析脚本的过程,通配符用于路径扩展,元字符用于多命令分割,转义符用于将特殊... 目录一、linux shell通配符(wildcard)二、shell元字符(特殊字符 Meta)三、s

Python脚本实现自动删除C盘临时文件夹

《Python脚本实现自动删除C盘临时文件夹》在日常使用电脑的过程中,临时文件夹往往会积累大量的无用数据,占用宝贵的磁盘空间,下面我们就来看看Python如何通过脚本实现自动删除C盘临时文件夹吧... 目录一、准备工作二、python脚本编写三、脚本解析四、运行脚本五、案例演示六、注意事项七、总结在日常使用

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.