如何设置XML规则以使用c#填充某些字段?

时间:2013-10-11 12:58:55

标签: c# xml

我有一个问题,我需要一些帮助。看看这些行:

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中,根据输出中的规则读取和解释它们并写入正确的值?

先谢谢你,伙计们!

2 个答案:

答案 0 :(得分:1)

尝试结帐:

  • 正则表达式
  • 使用XSD架构验证(我怀疑是这种情况)

可能它并不像你期望的那么酷,但无论如何

答案 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是强类型的,只能写一个字符串并从中读取。这也是一个例子,你有很多规则(节点),比如我跳过的列节点等。我希望你明白我写的内容。

如果你采用通用列的通用方法,可以容纳任何类型的任何类型,那么你将有更多困难的时间来制定规则来管理它。