支持泛型数组类型 List<int> List<bool> List<float> List<long> List<string>
This commit is contained in:
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
@@ -157,7 +157,7 @@ namespace ExcelTool
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (data.Item1.Equals("list"))
|
else if (data.Item1.Equals("list")) //List<Vector>类型
|
||||||
{
|
{
|
||||||
//[[1.2,3.4,5.6],[2.2,3.4,5.6],[3.2,3.4,5.6]]
|
//[[1.2,3.4,5.6],[2.2,3.4,5.6],[3.2,3.4,5.6]]
|
||||||
string str = data.Item2.ToString();
|
string str = data.Item2.ToString();
|
||||||
@@ -178,6 +178,60 @@ namespace ExcelTool
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (data.Item1.Contains("list<")) //泛型数组类型
|
||||||
|
{
|
||||||
|
string str = data.Item2.ToString();
|
||||||
|
if (string.IsNullOrEmpty(str))
|
||||||
|
{
|
||||||
|
bw.Write(Convert.ToInt32(0));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
var numStrs = str.Split(',');
|
||||||
|
bw.Write(numStrs.Length);
|
||||||
|
var tempS = data.Item1.Substring(5);
|
||||||
|
var listType = tempS.Substring(0, tempS.Length - 1);
|
||||||
|
if (listType.Equals("int"))
|
||||||
|
{
|
||||||
|
for (int i = 0; i < numStrs.Length; i++)
|
||||||
|
{
|
||||||
|
bw.Write(Convert.ToInt32(numStrs[i]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (listType.Equals("bool"))
|
||||||
|
{
|
||||||
|
for (int i = 0; i < numStrs.Length; i++)
|
||||||
|
{
|
||||||
|
bw.Write(Convert.ToBoolean(numStrs[i]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (listType.Equals("float"))
|
||||||
|
{
|
||||||
|
for (int i = 0; i < numStrs.Length; i++)
|
||||||
|
{
|
||||||
|
bw.Write(Convert.ToSingle(numStrs[i]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (listType.Equals("long"))
|
||||||
|
{
|
||||||
|
for (int i = 0; i < numStrs.Length; i++)
|
||||||
|
{
|
||||||
|
bw.Write(Convert.ToInt64(numStrs[i]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (listType.Equals("string"))
|
||||||
|
{
|
||||||
|
for (int i = 0; i < numStrs.Length; i++)
|
||||||
|
{
|
||||||
|
bw.Write(Convert.ToString(numStrs[i]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ConsoleHelper.WriteErrorLine("数组类型List<T>,T不是支持的Int,Float,String这三种类型,需要扩展类型");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ConsoleHelper.WriteErrorLine($"写入二进制文件,数据类型{data.Item1}没有适配");
|
ConsoleHelper.WriteErrorLine($"写入二进制文件,数据类型{data.Item1}没有适配");
|
||||||
|
|||||||
@@ -50,6 +50,35 @@ namespace ExcelTool
|
|||||||
{
|
{
|
||||||
sb.Append(string.Format("\tpublic List<List<float>> {0}", headers[i].FieldName));
|
sb.Append(string.Format("\tpublic List<List<float>> {0}", headers[i].FieldName));
|
||||||
}
|
}
|
||||||
|
else if (type.Contains("list<"))
|
||||||
|
{
|
||||||
|
var tempS = type.Substring(5);
|
||||||
|
var newType = tempS.Substring(0, tempS.Length - 1);
|
||||||
|
if (newType.Equals("int"))
|
||||||
|
{
|
||||||
|
sb.Append(string.Format("\tpublic List<int> {0}", headers[i].FieldName));
|
||||||
|
}
|
||||||
|
else if (newType.Equals("bool"))
|
||||||
|
{
|
||||||
|
sb.Append(string.Format("\tpublic List<bool> {0}", headers[i].FieldName));
|
||||||
|
}
|
||||||
|
else if (newType.Equals("float"))
|
||||||
|
{
|
||||||
|
sb.Append(string.Format("\tpublic List<float> {0}", headers[i].FieldName));
|
||||||
|
}
|
||||||
|
else if (newType.Equals("long"))
|
||||||
|
{
|
||||||
|
sb.Append(string.Format("\tpublic List<long> {0}", headers[i].FieldName));
|
||||||
|
}
|
||||||
|
else if (newType.Equals("string"))
|
||||||
|
{
|
||||||
|
sb.Append(string.Format("\tpublic List<string> {0}", headers[i].FieldName));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ConsoleHelper.WriteErrorLine("数组类型List<T>,T类型不支持");
|
||||||
|
}
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
sb.Append(string.Format("\tpublic {0} {1}", headers[i].FieldType.ToLower(), headers[i].FieldName));
|
sb.Append(string.Format("\tpublic {0} {1}", headers[i].FieldType.ToLower(), headers[i].FieldName));
|
||||||
@@ -116,6 +145,59 @@ namespace ExcelTool
|
|||||||
sb.Append($"\t\t\t{name} = null;\n");
|
sb.Append($"\t\t\t{name} = null;\n");
|
||||||
sb.Append("\t\t}\n");
|
sb.Append("\t\t}\n");
|
||||||
}
|
}
|
||||||
|
else if (type.Contains("list<"))
|
||||||
|
{
|
||||||
|
var tempS = type.Substring(5);
|
||||||
|
var listTType = tempS.Substring(0, tempS.Length - 1);
|
||||||
|
sb.Append($"\t\tvar {name}Count = reader.ReadInt32();\n");
|
||||||
|
sb.Append($"\t\tif ({name}Count > 0)\n");
|
||||||
|
sb.Append("\t\t{\n");
|
||||||
|
if (listTType.Equals("int"))
|
||||||
|
{
|
||||||
|
sb.Append($"\t\t\t{name} = new List<int>();\n");
|
||||||
|
sb.Append($"\t\t\tfor (int i = 0; i < {name}Count; i++)\n");
|
||||||
|
sb.Append("\t\t\t{\n");
|
||||||
|
sb.Append($"\t\t\t\t{name}.Add(reader.ReadInt32());\n");
|
||||||
|
}
|
||||||
|
else if (listTType.Equals("bool"))
|
||||||
|
{
|
||||||
|
sb.Append($"\t\t\t{name} = new List<bool>();\n");
|
||||||
|
sb.Append($"\t\t\tfor (int i = 0; i < {name}Count; i++)\n");
|
||||||
|
sb.Append("\t\t\t{\n");
|
||||||
|
sb.Append($"\t\t\t\t{name}.Add(reader.ReadBoolean());\n");
|
||||||
|
}
|
||||||
|
else if (listTType.Equals("float"))
|
||||||
|
{
|
||||||
|
sb.Append($"\t\t\t{name} = new List<float>();\n");
|
||||||
|
sb.Append($"\t\t\tfor (int i = 0; i < {name}Count; i++)\n");
|
||||||
|
sb.Append("\t\t\t{\n");
|
||||||
|
sb.Append($"\t\t\t\t{name}.Add(reader.ReadSingle());\n");
|
||||||
|
}
|
||||||
|
else if (listTType.Equals("long"))
|
||||||
|
{
|
||||||
|
sb.Append($"\t\t\t{name} = new List<long>();\n");
|
||||||
|
sb.Append($"\t\t\tfor (int i = 0; i < {name}Count; i++)\n");
|
||||||
|
sb.Append("\t\t\t{\n");
|
||||||
|
sb.Append($"\t\t\t\t{name}.Add(reader.ReadInt64());\n");
|
||||||
|
}
|
||||||
|
else if (listTType.Equals("string"))
|
||||||
|
{
|
||||||
|
sb.Append($"\t\t\t{name} = new List<string>();\n");
|
||||||
|
sb.Append($"\t\t\tfor (int i = 0; i < {name}Count; i++)\n");
|
||||||
|
sb.Append("\t\t\t{\n");
|
||||||
|
sb.Append($"\t\t\t\t{name}.Add(reader.ReadString());\n");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ConsoleHelper.WriteErrorLine("数组泛型T不是指定类型");
|
||||||
|
}
|
||||||
|
sb.Append("\t\t\t}\n");
|
||||||
|
sb.Append("\t\t}\n");
|
||||||
|
sb.Append("\t\telse\n");
|
||||||
|
sb.Append("\t\t{\n");
|
||||||
|
sb.Append($"\t\t\t{name} = null;\n");
|
||||||
|
sb.Append("\t\t}\n");
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ConsoleHelper.WriteErrorLine($"类型:{type}没有解析 {fileName}处理异常");
|
ConsoleHelper.WriteErrorLine($"类型:{type}没有解析 {fileName}处理异常");
|
||||||
@@ -167,6 +249,47 @@ namespace ExcelTool
|
|||||||
sb.Append("\t\t\t}\n");
|
sb.Append("\t\t\t}\n");
|
||||||
sb.Append("\t\t}\n");
|
sb.Append("\t\t}\n");
|
||||||
}
|
}
|
||||||
|
else if (type.Contains("list<"))
|
||||||
|
{
|
||||||
|
var tempS = type.Substring(5);
|
||||||
|
var listTType = tempS.Substring(0, tempS.Length - 1);
|
||||||
|
sb.Append($"\t\tif ({name} == null || {name}.Count == 0)\n");
|
||||||
|
sb.Append("\t\t{\n");
|
||||||
|
sb.Append("\t\t\twriter.Write(0);\n");
|
||||||
|
sb.Append("\t\t}\n");
|
||||||
|
sb.Append("\t\telse\n");
|
||||||
|
sb.Append("\t\t{\n");
|
||||||
|
sb.Append($"\t\t\twriter.Write({name}.Count);\n");
|
||||||
|
sb.Append($"\t\t\tfor (int i = 0; i < {name}.Count; i++)\n");
|
||||||
|
sb.Append("\t\t\t{\n");
|
||||||
|
sb.Append($"\t\t\t\twriter.Write({name}[i]);\n");
|
||||||
|
sb.Append("\t\t\t}\n");
|
||||||
|
sb.Append("\t\t}\n");
|
||||||
|
//if (listTType.Equals("int"))
|
||||||
|
//{
|
||||||
|
|
||||||
|
//}
|
||||||
|
//else if (listTType.Equals("bool"))
|
||||||
|
//{
|
||||||
|
|
||||||
|
//}
|
||||||
|
//else if (listTType.Equals("float"))
|
||||||
|
//{
|
||||||
|
|
||||||
|
//}
|
||||||
|
//else if (listTType.Equals("long"))
|
||||||
|
//{
|
||||||
|
|
||||||
|
//}
|
||||||
|
//else if (listTType.Equals("string"))
|
||||||
|
//{
|
||||||
|
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//{
|
||||||
|
// ConsoleHelper.WriteErrorLine("数组泛型T不是指定类型");
|
||||||
|
//}
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ConsoleHelper.WriteErrorLine($"类型:{type}没有解析 {fileName}处理异常");
|
ConsoleHelper.WriteErrorLine($"类型:{type}没有解析 {fileName}处理异常");
|
||||||
|
|||||||
Binary file not shown.
Binary file not shown.
Binary file not shown.
@@ -71,6 +71,10 @@ public partial class official_room : IBinarySerializable
|
|||||||
///
|
///
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public List<float> Offset { get; set; }
|
public List<float> Offset { get; set; }
|
||||||
|
/// <summary>
|
||||||
|
/// 测试数组
|
||||||
|
/// </summary>
|
||||||
|
public List<int> IntList { get; set; }
|
||||||
|
|
||||||
public void DeSerialize(BinaryReader reader)
|
public void DeSerialize(BinaryReader reader)
|
||||||
{
|
{
|
||||||
@@ -113,6 +117,19 @@ public partial class official_room : IBinarySerializable
|
|||||||
{
|
{
|
||||||
Offset = null;
|
Offset = null;
|
||||||
}
|
}
|
||||||
|
var IntListCount = reader.ReadInt32();
|
||||||
|
if (IntListCount > 0)
|
||||||
|
{
|
||||||
|
IntList = new List<int>();
|
||||||
|
for (int i = 0; i < IntListCount; i++)
|
||||||
|
{
|
||||||
|
IntList.Add(reader.ReadInt32());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
IntList = null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Serialize(BinaryWriter writer)
|
public void Serialize(BinaryWriter writer)
|
||||||
@@ -154,6 +171,18 @@ public partial class official_room : IBinarySerializable
|
|||||||
writer.Write(Offset[i]);
|
writer.Write(Offset[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (IntList == null || IntList.Count == 0)
|
||||||
|
{
|
||||||
|
writer.Write(0);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
writer.Write(IntList.Count);
|
||||||
|
for (int i = 0; i < IntList.Count; i++)
|
||||||
|
{
|
||||||
|
writer.Write(IntList[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,17 +1,17 @@
|
|||||||
"int,Id","string,RoomOwner","string,Notes","string,RoomName","string,RoomBriefly","string,RoomDetails","string,BgPathId","string,ScenesId","string,Address","int,Recommend","int,SubLine","int,IsCanPackage","int,IsMute","Vector,BirthPosition","Vector,Offset"
|
"int,Id","string,RoomOwner","string,Notes","string,RoomName","string,RoomBriefly","string,RoomDetails","string,BgPathId","string,ScenesId","string,Address","int,Recommend","int,SubLine","int,IsCanPackage","int,IsMute","Vector,BirthPosition","Vector,Offset","List<int>,IntList"
|
||||||
序号,,注释(产品用来自己备注的),默认名称(该场景的默认显示的名称),默认场景简述(该场景默认显示的简要描述信息,显示在官方房间入口上),场景详情(该场景的详细描述信息,显示在详情页中),背景图(对应显示在详情界面上的图片pathID或路径,希望能支持填写为一个表,即填多张,以支持轮播显示),对应场景ID(对应场景注册表中的场景ID),对应地图地址(对应高德上的地图地址,填对应点的经纬度,是否要同时把POI点名称填上,由程序确认),初始推荐排序(房间生成时的推荐优先级,确定初始显示位置,数字越低,优先级越高,后续会随着房间推荐算法变化),分线启用人数(达到多少人启用分线,不填或为0为不分线),客人是否可使用背包(在该房间中,客人不可以使用背包),进入默认静音,出生点坐标,
|
序号,,注释(产品用来自己备注的),默认名称(该场景的默认显示的名称),默认场景简述(该场景默认显示的简要描述信息,显示在官方房间入口上),场景详情(该场景的详细描述信息,显示在详情页中),背景图(对应显示在详情界面上的图片pathID或路径,希望能支持填写为一个表,即填多张,以支持轮播显示),对应场景ID(对应场景注册表中的场景ID),对应地图地址(对应高德上的地图地址,填对应点的经纬度,是否要同时把POI点名称填上,由程序确认),初始推荐排序(房间生成时的推荐优先级,确定初始显示位置,数字越低,优先级越高,后续会随着房间推荐算法变化),分线启用人数(达到多少人启用分线,不填或为0为不分线),客人是否可使用背包(在该房间中,客人不可以使用背包),进入默认静音,出生点坐标,,测试数组
|
||||||
1,TcjF8790673,福州峰会1号会场,福州峰会1号会场,可与三坊七巷主会场进行虚实互动的线上会场,一年一度的福州数字峰会在三坊七巷再度召开,通过分会场可实现虚实结合的体验,不仅可以在线上参与盛会,还会以数字分身的形式前往现实会场,与现场的用户进行互动,"{[""path1"":"""",""path2"":""""]}",1001,"{
|
1,TcjF8790673,福州峰会1号会场,福州峰会1号会场,可与三坊七巷主会场进行虚实互动的线上会场,一年一度的福州数字峰会在三坊七巷再度召开,通过分会场可实现虚实结合的体验,不仅可以在线上参与盛会,还会以数字分身的形式前往现实会场,与现场的用户进行互动,"{[""path1"":"""",""path2"":""""]}",1001,"{
|
||||||
""lat"":119.299236,
|
""lat"":119.299236,
|
||||||
""lon"":26.081825,
|
""lon"":26.081825,
|
||||||
""name"":""刘齐衔故居""
|
""name"":""刘齐衔故居""
|
||||||
}",0,100,0,1,"[-497.225,17.536,-107.682]","[0,0,0]"
|
}",0,100,0,1,"[-497.225,17.536,-107.682]","[0,0,0]","1,2,3,4,5"
|
||||||
2,TcjF8790673,101会议室,101会议室,东方万国D栋大会议室,东方万国D栋大会议室,可容纳20余人,"{[""path1"":"""",""path2"":""""]}",1002,"{
|
2,TcjF8790673,101会议室,101会议室,东方万国D栋大会议室,东方万国D栋大会议室,可容纳20余人,"{[""path1"":"""",""path2"":""""]}",1002,"{
|
||||||
""lat"":121.623633,
|
""lat"":121.623633,
|
||||||
""lon"":31.255969,
|
""lon"":31.255969,
|
||||||
""name"":""东方万国D栋""
|
""name"":""东方万国D栋""
|
||||||
}",0,100,0,1,"[-14243.48, 15.88, -3211.575]","[-14241.71,17.02,-3207.24]"
|
}",0,100,0,1,"[-14243.48, 15.88, -3211.575]","[-14241.71,17.02,-3207.24]",
|
||||||
3,TcjF8790673,外滩广场 ,外滩广场,上海市重要的地标场所之一,看万国建筑,观美丽江景。,外滩是上海市上海重要的地标之一,它全长1.5公里,南起延安东路,北至苏州河上的外白渡桥,东面即黄浦江,西面是旧上海金融、外贸机构的集中地。外滩沿路坐拥二十多幢风格各异的历史建筑,有折衷主义的,也有文艺复兴式的,还有早期现代式的,故而被誉为“万国建筑博览群”。自上海开埠后,外滩就开始成为了上海乃至中国的金融及贸易中心[1],也被称为“东方华尔街”。,"{[""path1"":"""",""path2"":""""]}",1003,"{
|
3,TcjF8790673,外滩广场 ,外滩广场,上海市重要的地标场所之一,看万国建筑,观美丽江景。,外滩是上海市上海重要的地标之一,它全长1.5公里,南起延安东路,北至苏州河上的外白渡桥,东面即黄浦江,西面是旧上海金融、外贸机构的集中地。外滩沿路坐拥二十多幢风格各异的历史建筑,有折衷主义的,也有文艺复兴式的,还有早期现代式的,故而被誉为“万国建筑博览群”。自上海开埠后,外滩就开始成为了上海乃至中国的金融及贸易中心[1],也被称为“东方华尔街”。,"{[""path1"":"""",""path2"":""""]}",1003,"{
|
||||||
""lat"":121.492156,
|
""lat"":121.492156,
|
||||||
""lon"":31.233462,
|
""lon"":31.233462,
|
||||||
""name"":""外滩""
|
""name"":""外滩""
|
||||||
}",1,100,0,1,"[-1631.85,13.904,-888.18]","[-1490,0,-1370]"
|
}",1,100,0,1,"[-1631.85,13.904,-888.18]","[-1490,0,-1370]",
|
||||||
|
|||||||
|
Binary file not shown.
@@ -1 +1 @@
|
|||||||
5be383d8458e8adf3321425f1a6ef7ed98f16846
|
05ba930c17cc8f5ba2765e4f9b5fad95a2f8ca8f
|
||||||
|
|||||||
@@ -51,3 +51,4 @@ D:\Study\github\ExcelTool\ExcelTool\obj\Debug\ExcelTool.csproj.CoreCompileInputs
|
|||||||
D:\Study\github\ExcelTool\ExcelTool\obj\Debug\ExcelTool.csproj.CopyComplete
|
D:\Study\github\ExcelTool\ExcelTool\obj\Debug\ExcelTool.csproj.CopyComplete
|
||||||
D:\Study\github\ExcelTool\ExcelTool\obj\Debug\ExcelTool.exe
|
D:\Study\github\ExcelTool\ExcelTool\obj\Debug\ExcelTool.exe
|
||||||
D:\Study\github\ExcelTool\ExcelTool\obj\Debug\ExcelTool.pdb
|
D:\Study\github\ExcelTool\ExcelTool\obj\Debug\ExcelTool.pdb
|
||||||
|
D:\study\github\ExcelTool\ExcelTool\obj\Debug\ExcelTool.csprojAssemblyReference.cache
|
||||||
|
|||||||
Binary file not shown.
Binary file not shown.
Binary file not shown.
Reference in New Issue
Block a user