Text格式的配置表读取

sing System.Collections.Generic;
using System.IO;
using System;
using System.Reflection;
using UnityEngine;


public class TextConverter {
    private static string[] lineContents;


    public static List<T> GetTypeData<T>(string fileName) where T : class, new()
    {
        List<T> mlist = new List<T>();
        TextAsset binAsset = LoadConfig("Config/"+ fileName, typeof(TextAsset)) as TextAsset;
        lineContents = binAsset.text.Split('\r'); //获取所有行的数据
        string[] keys = lineContents[0].Split('\t');//获取配置表第一行的字段名
        for (int i = 2; i < lineContents.Length; i++)
        {
            T t = new T();
            string[] values = lineContents[i].Split('\t');
            if (values.Length == 1)
                break;
            for (int j = 0; j < values.Length; j++)
            {
                FieldInfo f = t.GetType().GetField(keys[j]);
                //Debug.Log(keys[j] + ":" + values[j]);
                f.SetValue(t, Convert.ChangeType(values[j], f.FieldType));
            }
            mlist.Add(t);
        }
        return mlist;

    }


public static Object LoadConfig(string name, System.Type type)
    {
        Object obj = null;
       
        obj = UnityEditor.AssetDatabase.LoadAssetAtPath("Assets/" + name + ".txt", type);
        return obj;
    }

}
读取配置文件并创建多张数据库,你需要使用 Qt 的 QSettings 类来读取配置文件中的数据库连接信息,然后使用 QSqlDatabase 类来连接数据库并创建。 以下是一个简单的示例代码,假设你的配置文件是一个 INI 文件,包含了数据库连接的信息: ``` [database] driver=mysql host=localhost port=3306 database=test username=root password= [tables] table1=create table if not exists table1 (id int primary key, name varchar(20)); table2=create table if not exists table2 (id int primary key, value int); ``` 接下来,你可以使用以下代码来读取配置文件并创建多张数据库: ```cpp // 读取配置文件 QSettings settings("config.ini", QSettings::IniFormat); QString driver = settings.value("database/driver").toString(); QString host = settings.value("database/host").toString(); int port = settings.value("database/port").toInt(); QString databaseName = settings.value("database/database").toString(); QString username = settings.value("database/username").toString(); QString password = settings.value("database/password").toString(); // 连接数据库 QSqlDatabase db = QSqlDatabase::addDatabase(driver); db.setHostName(host); db.setPort(port); db.setDatabaseName(databaseName); db.setUserName(username); db.setPassword(password); if (!db.open()) { qDebug() << "Failed to connect to database"; return; } // 创建 QStringList tables = settings.value("tables", QStringList()).toStringList(); foreach (QString table, tables) { QSqlQuery query(table, db); if (!query.exec()) { qDebug() << "Failed to create table: " << query.lastError().text(); } } ``` 注意,这只是一个简单的示例代码,实际情况中你需要根据自己的需求进行修改和完善。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值