コード例 #1
0
        private static string CreateData(IniStructure IniData, string comment)
        {               //Iterates through all categories and keys and appends all data to Data
            int CategoryCount = IniData.GetCategories().Length;

            int[]  KeyCountPerCategory = new int[CategoryCount];
            string Data = comment;

            string[] temp = new string[2];             // will contain key-value pair

            for (int i = 0; i < CategoryCount; i++)    // Gets keycount per category
            {
                string CategoryName = IniData.GetCategories()[i];
                KeyCountPerCategory[i] = IniData.GetKeys(CategoryName).Length;
            }

            for (int catcounter = 0; catcounter < CategoryCount; catcounter++)
            {
                Data += "\r\n[" + IniData.GetCategoryName(catcounter) + "]\r\n";
                // writes [Category] to Data
                for (int keycounter = 0; keycounter < KeyCountPerCategory[catcounter]; keycounter++)
                {
                    temp[0] = IniData.GetKeyName(catcounter, keycounter);
                    temp[1] = IniData.GetValue(catcounter, keycounter);
                    Data   += temp[0] + "=" + temp[1] + "\r\n";
                    // writes the key-value pair to Data
                }
            }
            return(Data);
        }
コード例 #2
0
ファイル: IniHandler.cs プロジェクト: viticm/pap2
		private static string CreateData(IniStructure IniData, string comment)
		{	//Iterates through all categories and keys and appends all data to Data
			int CategoryCount = IniData.GetCategories().Length;
			int[] KeyCountPerCategory = new int[CategoryCount];
			string Data = comment;
			string[] temp = new string[2]; // will contain key-value pair
			
			for (int i = 0; i < CategoryCount; i++) // Gets keycount per category
			{
				string CategoryName = IniData.GetCategories()[i];
				KeyCountPerCategory[i] = IniData.GetKeys(CategoryName).Length;
			}

			for (int catcounter = 0; catcounter < CategoryCount; catcounter++)
			{
				Data += "\r\n[" + IniData.GetCategoryName(catcounter) + "]\r\n"; 
				// writes [Category] to Data
				for (int keycounter = 0; keycounter < KeyCountPerCategory[catcounter]; keycounter++)
				{
					temp[0] = IniData.GetKeyName(catcounter, keycounter);
					temp[1] = IniData.GetValue(catcounter, keycounter);
					Data += temp[0] + "=" + temp[1] + "\r\n";
					// writes the key-value pair to Data
				}
			}
			return Data;
		}
コード例 #3
0
        public bool Export(SqlConnection Conn, string RootDir)
        {
            bool          bResult = true;
            StringBuilder sb      = new StringBuilder();

            sb.Append("LinkID\tMapID\tNpcID\tKind\tx\ty\tz\tNpcName\r\n");

            String    sql = "Select * from CareerGuide";
            DataTable tbl = Helper.GetDataTable(sql, Conn);

            //按地图划分
            sql = "Select MapID from CareerGuide where MapID > 0 group by MapID";
            DataTable tblMapID = Helper.GetDataTable(sql, Conn);
            ArrayList alMapID  = new ArrayList();

            foreach (DataRow dr in tblMapID.Rows)
            {
                alMapID.Add((object)dr["MapID"].ToString());
                DataRow[] rows = tbl.Select("MapID = " + dr["MapID"].ToString());

                sql = "select Name from MapList where ID = " + dr["MapID"].ToString();
                DataTable dt         = Helper.GetDataTable(sql, Conn);
                String    strMapName = dt.Rows[0][0].ToString();
                if (strMapName == "测试1")
                {
                    strMapName = RootDir + "\\data\\source\\maps\\测试\\" + strMapName + ".Map.Logical";
                }
                else
                {
                    strMapName = RootDir + "\\data\\source\\maps\\" + strMapName + "\\" + strMapName + ".Map.Logical";
                }

                String            strRetVal;
                String            strContent = Helper.FileToString(strMapName);
                Misc.IniStructure m_inis     = new Misc.IniStructure();
                m_inis = Misc.IniStructure.ReadIniWithContent(strContent);

                //遍历Logical文件中npc
                strRetVal = m_inis.GetValue("MAIN", "NumNPC");
                int nNPCCount = Int32.Parse(strRetVal);
                for (int nIndex = 0; nNPCCount > nIndex; nIndex++)
                {
                    String strSectionName = "NPC" + nIndex.ToString();
                    strRetVal = m_inis.GetValue(strSectionName, "nTempleteID");
                    int nTempleteID = Int32.Parse(strRetVal);

                    foreach (DataRow row in rows)
                    {
                        if (nTempleteID == Int32.Parse(row["NpcID"].ToString()))
                        {
                            strRetVal = m_inis.GetValue(strSectionName, "nX");
                            row["x"]  = strRetVal.ToString();
                            strRetVal = m_inis.GetValue(strSectionName, "nY");
                            row["y"]  = strRetVal.ToString();
                            strRetVal = m_inis.GetValue(strSectionName, "nZ");
                            row["z"]  = strRetVal.ToString();
                        }
                    }
                }
            }

            foreach (DataRow row in tbl.Rows)
            {
                sb.Append(row["LinkID"].ToString() + "\t");
                sb.Append(row["MapID"].ToString() + "\t");
                sb.Append(row["NpcID"].ToString() + "\t");
                sb.Append(row["Kind"].ToString() + "\t");
                sb.Append(row["x"].ToString() + "\t");
                sb.Append(row["y"].ToString() + "\t");
                sb.Append(row["z"].ToString() + "\t");
                sb.Append(row["NpcName"].ToString() + "\r\n");
                if (row["NpcID"].ToString() != "0" &&
                    (row["x"].ToString() == "" ||
                     row["y"].ToString() == "" ||
                     row["z"].ToString() == ""))
                {
                    Console.Write("NPC:" + row["NpcID"].ToString() + "未找到对应坐标!\n");
                }
            }

            sql = "Select filename from sys_export_table_cfg where tablename = 'CareerGuide'";
            tbl = Helper.GetDataTable(sql, Conn);
            String strFileName = tbl.Rows[0][0].ToString();

            strFileName = RootDir + strFileName;
            Helper.StringToFile(sb.ToString(), strFileName, Encoding.GetEncoding("gb2312"));

            return(bResult);
        }
コード例 #4
0
ファイル: Class1.cs プロジェクト: viticm/pap2
        public bool Export(SqlConnection Conn, string RootDir)
        {
            bool bResult = true;
            StringBuilder sb = new StringBuilder();
            sb.Append("LinkID\tMapID\tNpcID\tKind\tx\ty\tz\tNpcName\r\n");

            String sql = "Select * from CareerGuide";
            DataTable tbl = Helper.GetDataTable(sql, Conn);
            
            //按地图划分
            sql = "Select MapID from CareerGuide where MapID > 0 group by MapID";
            DataTable tblMapID = Helper.GetDataTable(sql, Conn);
            ArrayList alMapID = new ArrayList();
            foreach (DataRow dr in tblMapID.Rows)
            {
                alMapID.Add((object)dr["MapID"].ToString());
                DataRow[] rows = tbl.Select("MapID = " + dr["MapID"].ToString());

                sql = "select Name from MapList where ID = " + dr["MapID"].ToString();
                DataTable dt = Helper.GetDataTable(sql, Conn);
                String strMapName = dt.Rows[0][0].ToString();
                if (strMapName == "测试1")
                    strMapName = RootDir + "\\data\\source\\maps\\测试\\" + strMapName + ".Map.Logical";
                else
                    strMapName = RootDir + "\\data\\source\\maps\\" + strMapName + "\\" + strMapName + ".Map.Logical";

                String strRetVal;
                String strContent = Helper.FileToString(strMapName);
                Misc.IniStructure m_inis = new Misc.IniStructure();
                m_inis = Misc.IniStructure.ReadIniWithContent(strContent);

                //遍历Logical文件中npc
                strRetVal = m_inis.GetValue("MAIN", "NumNPC");
                int nNPCCount = Int32.Parse(strRetVal);
                for (int nIndex = 0; nNPCCount > nIndex; nIndex++)
                {
                    String strSectionName = "NPC" + nIndex.ToString();
                    strRetVal = m_inis.GetValue(strSectionName, "nTempleteID");
                    int nTempleteID = Int32.Parse(strRetVal);
                    
                    foreach (DataRow row in rows)
                    {
                        if (nTempleteID == Int32.Parse(row["NpcID"].ToString()))
                        {
                        strRetVal = m_inis.GetValue(strSectionName, "nX");
                        row["x"] = strRetVal.ToString();
                        strRetVal = m_inis.GetValue(strSectionName, "nY");
                        row["y"] = strRetVal.ToString();
                        strRetVal = m_inis.GetValue(strSectionName, "nZ");
                        row["z"] = strRetVal.ToString();
                        }
                    }
                }
            }

            foreach (DataRow row in tbl.Rows)
            {
                sb.Append(row["LinkID"].ToString() + "\t");
                sb.Append(row["MapID"].ToString() + "\t");
                sb.Append(row["NpcID"].ToString() + "\t");
                sb.Append(row["Kind"].ToString() + "\t");
                sb.Append(row["x"].ToString() + "\t");
                sb.Append(row["y"].ToString() + "\t");
                sb.Append(row["z"].ToString() + "\t");
                sb.Append(row["NpcName"].ToString() + "\r\n");
                if (row["NpcID"].ToString() != "0" && 
                    (row["x"].ToString() == "" ||
                   row["y"].ToString() == "" ||
                   row["z"].ToString() == ""))
                {
                    Console.Write("NPC:" + row["NpcID"].ToString() + "未找到对应坐标!\n");
                }
            }

            sql = "Select filename from sys_export_table_cfg where tablename = 'CareerGuide'";
            tbl = Helper.GetDataTable(sql, Conn);
            String strFileName = tbl.Rows[0][0].ToString();
            strFileName = RootDir + strFileName;
            Helper.StringToFile(sb.ToString(), strFileName, Encoding.GetEncoding("gb2312"));

            return bResult;
        }