如何设置 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中描述这些规则,读取和解释它们并根据输出中的规则写入正确的值?
提前感谢,伙计们!
尝试结帐:
- 正则表达式
- 使用 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 是强类型的,只能向其写入字符串并从中读取。 这也是一个例子,你有更多的规则(节点(,如列节点等,我跳过了。 我希望你明白我写的重点。
如果你采用可以容纳任何内容和任何类型的泛型列的通用方法,那么你将面临更困难的时间来开发规则来管理这一切。