XmlTextWriter 클래스
이 섹션의 메서드를 사용하여 XML 문서를 만드는 것은 확실히 어렵지 않습니다. 수년 동안 개발자들은 캐시의 일부 문자열을 연결한 다음 캐시된 문자열을 파일로 출력하여 XML 문서를 작성해 왔습니다. 그러나 이런 방식으로 XML 문서를 생성하는 것은 문자열에 작은 오류가 없는지 확인한 경우에만 작동합니다. .NET Framework는 XMLwriter를 사용하여 XML 문서를 만드는 더 나은 방법을 제공합니다.
?? XML Writer 클래스는 정방향 전용 방식으로 XML 데이터를 스트림이나 파일로 출력합니다. 더 중요한 점은 XML Writer가 모든 XML 데이터가 W3C XML 1.0 권장 사양을 준수하도록 설계되었다는 점입니다. XML Writer가 자동으로 닫는 태그를 작성해 주기 때문에 닫는 태그를 작성하는 것을 잊어버릴 염려도 없습니다. XmlWriter는 모든 XML 작성기에 대한 추상 기본 클래스입니다. .NET Framework는 하나의 작성기 클래스----XmlTextWriter 클래스만 제공합니다.
?? 먼저 XML 작성기와 기존 작성기의 차이점을 살펴보겠습니다. 다음 코드는 문자열 유형의 배열을 유지합니다.
StringBuilder sb = new StringBuilder('')
sb.Append('');
foreach(string s in theArray) {
sb.Append('
sb.Append(''/>')
}
sb.Append('' ) ;
??코드는 루프를 통해 데이터의 요소를 꺼내서 레이블 텍스트를 쓰고 이를 문자열에 누적합니다. 코드는 출력 콘텐츠의 형식이 올바른지 확인하고 새 줄 들여쓰기에 주의하며 네임스페이스를 지원합니다. 이 접근 방식은 생성한 문서 구조가 비교적 단순한 경우 오류가 없을 수 있습니다. 그러나 지시문, 네임스페이스, 들여쓰기, 형식 지정 및 엔터티 처리를 지원해야 하는 경우 코드 양이 기하급수적으로 증가하고 오류 가능성도 늘어납니다.
XML 작성기 작성 방법 기능은 가능한 모든 XML 노드 유형에 대응하므로 XML 문서 작성 프로세스가 보다 논리적이고 번거로운 마크업 언어에 대한 의존도가 줄어듭니다. 그림 6에서는 XmlTextWriter 클래스의 메서드를 사용하여 문자열 데이터를 연결하는 방법을 보여줍니다. 코드가 매우 간결하고 XML 작성기를 사용하는 코드가 읽기 쉽고 구조도 좋습니다.
그림 6 문자열 배열 직렬화
void CreateXmlFileUsingWriters(String[] theArray, string filename)
{
// XML 작성기를 엽니다(사용 기본 문자 집합)
XmlTextWriter xmlw = new XmlTextWriter(filename, null);
xmlw.Formatting = Formatting.Indented;
WriteStartDocument ();
xmlw.WriteStartElement('array');
foreach(string s in theArray)
{
xmlw.WriteStartElement(' 요소 ');
xmlw.WriteAttributeString('value', s);
xmlw.WriteEndElement()
xmlw.WriteEndDocument( ) ;
// 작성기 닫기
xmlw.Close();
}
??그러나 XML 작성기는 마술사가 아닙니다. 입력 오류를 수정할 수 없습니다. XML 기록기는 요소 및 속성 이름이 유효한지 확인하지 않으며 사용된 유니코드 문자 집합이 현재 아키텍처의 인코딩 집합에 적합한지 확인하지도 않습니다. 위에서 언급한 것처럼 출력 오류를 방지하려면 XML이 아닌 문자를 제거해야 합니다. 하지만 작가는 이 방법을 제공하지 않는다.
?? 게다가 속성 노드를 생성할 때 라이터는 속성 노드의 이름이 기존 요소 노드의 이름과 같은지 확인하지 않습니다. 마지막으로 XmlWriter 클래스는 검증된 Writer 클래스가 아니며 출력이 스키마 또는 DTD를 준수하는지 여부를 보장하지 않습니다. .NET Framework에서 유효성 검사가 포함된 작성기 클래스는 현재 제공되지 않습니다. 그러나 내 책 "Microsoft .NET을 위한 응용 XML 프로그래밍(Microsoft Press®, 2002)"에서 검증된 Writer 구성 요소를 작성했습니다. 다음 URL에서 소스 코드를 다운로드할 수 있습니다: http://www.microsoft.com/MSPress/books/6235.asp
?? 그림 7에는 일부 상태 값이 나열되어 있습니다. XML 작가의 . 이 값은 WriteState 열거형 클래스에서 파생됩니다. 작성기를 생성할 때 초기 상태는 시작이며, 이는 실제로 작성기가 시작되지 않았음을 나타냅니다. 다음 상태는 작업을 시작하기 위해 WriteStartDocument 메서드를 호출할 때 설정되는 Prolog입니다. 그러면 작성하는 문서와 문서의 내용에 따라 상태 전환이 달라집니다. 프롤로그 상태는 주석 요소, 처리 지침, 문서 유형 등 요소가 아닌 노드를 추가할 때까지 유지됩니다. 루트 노드인 첫 번째 노드가 기록되면 상태가 요소로 변경됩니다. 특성을 쓰기 위해 WriteAtributeString 메서드를 호출할 때가 아니라 WriterStartAtribute 메서드를 호출할 때 상태가 Attribute로 변환됩니다. 이 경우 상태는 요소여야 합니다. 닫는 태그(>)를 쓰면 상태가 Content로 변환됩니다. 문서 쓰기가 끝나면 WriteEndDocument 메서드를 호출하면 다른 문서 쓰기를 시작하거나 Writer를 끌 때까지 상태가 시작으로 돌아갑니다.
위 내용은 .NET Framework에서 XML 데이터를 쉽게 처리하는 내용(4-1)입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!