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

本文关键字:填充 字段 规则 何设置 设置 XML | 更新日期: 2023-09-27 18:34:50

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

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 配置

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

提前感谢,伙计们!

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

尝试结帐:

  • 正则表达式
  • 使用 XSD 架构进行验证(我怀疑情况是否如此(

可能这不是你期望的那么酷的答案,但无论如何

如果为每种类型创建类,则具有规则。您将拥有用于读取/写入该 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 是强类型的,只能向其写入字符串并从中读取。 这也是一个例子,你有更多的规则(节点(,如列节点等,我跳过了。 我希望你明白我写的重点。

如果你采用可以容纳任何内容和任何类型的泛型列的通用方法,那么你将面临更困难的时间来开发规则来管理这一切。