Qt:QXmlStreamReader,QXmlStreamWriter读写xml文件

1.读xml
	QFile file(QCoreApplication::applicationDirPath() + "/config/Setting.xml");
	if (file.open(QIODevice::ReadOnly | QIODevice::Text))
	{
		QXmlStreamReader reader(&file);
		QString name = "";
		int col = 0;
		bool select = false;
		while (!reader.atEnd())
		{
			//逐个读取Element
			if (reader.isStartElement())
			{
				if (reader.name() == "Name")
				{
					name = reader.readElementText();
				}
				else if (reader.name() == "ImportCol")
				{
					col = reader.readElementText().toInt();
				}
				else if (reader.name() == "Select")
				{
					select = reader.readElementText().toUInt();
				}
			}
			else if (reader.isEndElement() && reader.name() == "Date")
			{
				g_import_excel_setting.modify_import_setting(name, col, select);
			}
			reader.readNext();//转至下一个元素
		}
		file.close();
	}
2.写xml
QFile file(QCoreApplication::applicationDirPath() + "/config/Setting.xml");
	if (file.open(QIODevice::WriteOnly))
	{
		QXmlStreamWriter writer(&file);
		writer.setAutoFormatting(true);//自动格式
		writer.writeStartDocument();//开始写文件
		
		writer.writeStartElement("Param",);
		
		writer.writeStartElement("Date",);
		writer.writeAttribute("id", 1));
		
		writer.writeTextElement("Name",u8("小明") );
		writer.writeTextElement("ImportCol", 1);
		writer.writeTextElement("Select", 1);
		
		writer.writeEndElement();
		writer.writeEndElement();
		
		writer.writeEndDocument();
		file.close();
	}
}

可得如下:

<Param>
    <Date id="1">
        <Name>小明</Name>
        <ImportCol>1</ImportCol>
        <Select>1</Select>
    </Date>
</Param>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值