lua读取xml

现有的数据库结构无法满足新需求,暂时得用脚本实现一下数据库的功能

首先得把数据取出来,当然不能手动,所以用了这个简单的方法

<RECORDS>
<RECORD>
	<id>1392</id>
	<osver>10000</osver>
	<appver>0</appver>
	<tag>0</tag>
	<channelid>0</channelid>
	<itemid>91014</itemid>
	<gameid>9</gameid>
</RECORD>
<RECORD>
	<id>1391</id>
	<osver>10000</osver>
	<appver>0</appver>
	<tag>0</tag>
	<channelid>0</channelid>
	<itemid>91013</itemid>
	<gameid>9</gameid>
</RECORD>
这是其中两条,现在就需要写脚本来处理了

require("LuaXml")
local file = xml.load("config_store_spec.xml")
local date = file:find("RECORDS")
local dateTable = {}

if date ~= nil then

	local n = 1
	local m = 1

	while date[n] ~= nil do
		m = 1
		local oneDate = {}
		while date[n][m] ~= nil do
			oneDate[(date[n][m][0])] = date[n][m][1]
			m = m + 1
		end
		dateTable[n] = oneDate
		n = n + 1
	end
end
这样就保存到table里了


以下为LuaXml的常用函数:
xml.new(arg)
创建一个新的XML对象


xml.append(var,tag)
添加一个子节点


xml.load(filename)
加载XML文件


xml.save(var,filename)
保存XML文件


xml.eval(xmlstring)
解析XML字符串


xml.tag(var, tag)
设置或返回一个XML对象


xml.str(var, indent, tag)
以字符串形式返回XML


xml.find(var, tag, attributeKey,attributeValue)
查找子节点


xml.registerCode(decoded,encoded)
设置文件编码类型

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
XML转换为Lua通常分为两个步骤:解析XML文件和生成Lua代码。 首先,要解析XML文件,可以使用LuaXML解析库,例如LuaExpat、LuaXMLluaxpath等。这些库可以帮助我们解析XML文件并将其转换为Lua中的数据结构。 其次,要生成Lua代码,可以根据XML的结构和内容,使用Lua的字符串拼接操作来生成Lua代码。根据XML的标签、属性和值的不同,可以采用不同的转换方式,例如创建Lua表、赋值、设置属性等。 以下是一个示例,演示了如何将XML转换为Lua: 假设我们有以下的XML文件example.xml: ``` <root> <person name="Alice" age="30" gender="female"> <interests> <interest>Sports</interest> <interest>Reading</interest> </interests> </person> <person name="Bob" age="35" gender="male"> <interests> <interest>Cooking</interest> <interest>Photography</interest> </interests> </person> </root> ``` 使用LuaXML库可以解析这个XML文件: ```lua local xml = require("LuaXML") local file = io.open("example.xml", "r") local data = file:read("*a") file:close() local x = xml.eval(data) local root = x:find("root") local persons = {} for i, person in ipairs(root:find("person")) do local p = {} p.name = person.attr.name p.age = tonumber(person.attr.age) p.gender = person.attr.gender p.interests = {} for i, interest in ipairs(person:find("interests")[1]:find("interest")) do table.insert(p.interests, interest:value()) end table.insert(persons, p) end ``` 上述代码将会生成一个名为`persons`的Lua表,其中包含了XML文件中所有的`person`节点的信息。可以通过访问`persons`表来获取这些节点的属性和值,以及`interests`子节点的内容。 需要注意的是,实际的XML结构可能更加复杂,因此在转换过程中可能需要添加更多的逻辑和处理步骤来满足具体的需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值