我有一个问题,我需要一些帮助。看看这些行:
HEADING
TYPE NAME PBOR0 SHOP CATREF DETAIL MATXT CMPREF BLTREF TMPREF PRTREF
DEFAULTS
- - - =
TUBE */Cb_N76f-RDX/T0A2013010-00:DD 0.50 TRUE /RDX_R_AAPA1A0DD /RDX_T0A2013010-00 /RDX_VAZIO-MT /Cb_N76f-RDX/RDX_T0A0AC0010-00:DD =0 =0 =0
还有以下几行:
HEADING
TYPE NAME PBOR0 STYP SHOP CATREF DETAIL MATXT CMPREF BLTREF TMPREF PRTREF
DEFAULTS
- - - CT =
ELBO */C9B0020101-00:DD 0.50 CT TRUE /RDX_R_ABEB360DD /C9B0020101-00 /RDX_VAZIO-MT /Cb_N76f-RDX/RDX_C9B002AC01-00:DD =0 =0 =0
如上所示,第一个块来自TUBE,第二个块来自ELBO。两者都有不同的标题列。这个问题我解决了像这样的xml configuraiton:
<?xml version="1.0" encoding="UTF-8"?>
<Components>
<Component type="TUBE">
<Header size="11">
<Columns>
<Column>
<Name>TYPE</Name>
<Defaults>-</Defaults>
</Column>
<Column>
<Name>NAME</Name>
<Defaults>-</Defaults>
</Column>
<Column>
<Name>PBOR0</Name>
<Defaults>-</Defaults>
</Column>
<Column>
<Name>SHOP</Name>
<Defaults>=</Defaults>
</Column>
<Column>
<Name>CATREF</Name>
<Defaults></Defaults>
</Column>
<Column>
<Name>DETAIL</Name>
<Defaults></Defaults>
</Column>
<Column>
<Name>MATXT</Name>
<Defaults></Defaults>
</Column>
<Column>
<Name>CMPREF</Name>
<Defaults></Defaults>
</Column>
<Column>
<Name>BLTREF</Name>
<Defaults></Defaults>
</Column>
<Column>
<Name>TMPREF</Name>
<Defaults></Defaults>
</Column>
<Column>
<Name>PRTREF</Name>
<Defaults></Defaults>
</Column>
</Columns>
</Header>
</Component>
<Component type="ELBO">
<Header size="12">
<Columns>
<Column>
<Name>TYPE</Name>
<Defaults>-</Defaults>
</Column>
<Column>
<Name>NAME</Name>
<Defaults>-</Defaults>
</Column>
<Column>
<Name>PBOR0</Name>
<Defaults>-</Defaults>
</Column>
<Column>
<Name>STYP</Name>
<Defaults>CT</Defaults>
</Column>
<Column>
<Name>SHOP</Name>
<Defaults>=</Defaults>
</Column>
<Column>
<Name>CATREF</Name>
<Defaults></Defaults>
</Column>
<Column>
<Name>DETAIL</Name>
<Defaults></Defaults>
</Column>
<Column>
<Name>MATXT</Name>
<Defaults></Defaults>
</Column>
<Column>
<Name>CMPREF</Name>
<Defaults></Defaults>
</Column>
<Column>
<Name>BLTREF</Name>
<Defaults></Defaults>
</Column>
<Column>
<Name>TMPREF</Name>
<Defaults></Defaults>
</Column>
<Column>
<Name>PRTREF</Name>
<Defaults></Defaults>
</Column>
</Columns>
</Header>
</Component>
<Component type="GASKET">
<Header size="12">
<Columns>
<Column>
<Name>TYPE</Name>
<Defaults>-</Defaults>
</Column>
<Column>
<Name>NAME</Name>
<Defaults>-</Defaults>
</Column>
<Column>
<Name>PBOR0</Name>
<Defaults>-</Defaults>
</Column>
<Column>
<Name>STYP</Name>
<Defaults>RF</Defaults>
</Column>
<Column>
<Name>SHOP</Name>
<Defaults>=</Defaults>
</Column>
<Column>
<Name>CATREF</Name>
<Defaults></Defaults>
</Column>
<Column>
<Name>DETAIL</Name>
<Defaults></Defaults>
</Column>
<Column>
<Name>MATXT</Name>
<Defaults></Defaults>
</Column>
<Column>
<Name>CMPREF</Name>
<Defaults></Defaults>
</Column>
<Column>
<Name>BLTREF</Name>
<Defaults></Defaults>
</Column>
<Column>
<Name>TMPREF</Name>
<Defaults></Defaults>
</Column>
<Column>
<Name>PRTREF</Name>
<Defaults></Defaults>
</Column>
</Columns>
</Header>
</Component>
</Components>
现在的问题是:我在列中编写值有很多不同的规则,例如:要编写NAME,我必须遵循某些规则,将STYP写成另一个,等等。有一种简单易用的方法来描述这些规则在XML中,根据输出中的规则读取和解释它们并写入正确的值?
先谢谢你,伙计们!
答案 0 :(得分:1)
尝试结帐:
可能它并不像你期望的那么酷,但无论如何
答案 1 :(得分:1)
如果您为每种类型创建类,那么您将拥有规则。您可以使用该xml读取/写入的API。用C#编写的类的优点是强类型。
实施例,
public class Elbo
{
XElement self;
public Elbo(XElement elbo) { self = elbo; }
public string Name
{
get { return self.Element("Name").Value; }
set
{
XElement name = self.Element("Name");
if(null == name)
self.Add(name = new XElement("Name"));
name.Value = value;
}
}
}
现在Name是强类型的,只能写一个字符串并从中读取。这也是一个例子,你有很多规则(节点),比如我跳过的列节点等。我希望你明白我写的内容。
如果你采用通用列的通用方法,可以容纳任何类型的任何类型,那么你将有更多困难的时间来制定规则来管理它。