Một số kỹ thuật xử lý biến đổi tài liệu XML với XSLT
Mục tiêu : Trình bày một số kỹ thuật cơ bản cho phép thể hiện nội dung tập tin Xml trên trang Web với tập tin Xml Don_thuc.xml <DON_THUC He_so="4" So_mu="6" /> chương trình Xslt sau ...
Mục tiêu :
Trình bày một số kỹ thuật cơ bản cho phép thể hiện nội dung tập tin Xml trên trang Web
với tập tin Xml Don_thuc.xml
<DON_THUC He_so="4" So_mu="6" />
chương trình Xslt sau sẽ cho phép thể hiện đơn thức dưới dạng trình bày trên Web 4x6
Chương trình Xuat_don_thuc.xslt
<?xmlversion="1.0"encoding="UTF-8" ?>
<xsl:stylesheetversion="1.0"xmlns:xsl=
"http://www.w3.org/1999/XSL/Transform
">
<xsl:outputmethod ="html" />
<xsl:templatematch="/" >
<html>
<body>
<xsl:apply-templates />
</body>
</html>
</xsl:template>
<xsl:templatematch="DON_THUC" > P(x)=
<xsl:value-ofselect =
"@He_so"
/> x
<sup>
<xsl:value-ofselect =
"@So_mu
"/>
</sup>
</xsl:template>
</xsl:stylesheet>
* XML -- > Thẻ select
Vấn đề :
Cần xuất danh sách chọn trên trang Web từ một danh sách các nút của tập tin Xml trong một ứng dụng
Web
Xuất danh sách các mặt hàng
Xuất danh sách các đơn vị
Xuất danh sách các khối
....
Hướng giải quyết :
Sử dụng thẻ select , option của ngôn ngữ Html
....
<select>
<xsl:apply-templates select="Biểu thức Xpath tương ứng danh sách" />
</select>
....
<xsl:template match="Biểu thức Xpath tương ứng một phần tử trong danh sách" >
<option>
Thẻ xử lý kết xuất giá trị
</option>
</xsl:template>
Chương trình Xslt sau sẽ xuất danh sách chọn các đơn vị từ tập tin Cong_ty.xml
<?xmlversion="1.0"encoding="UTF-8" ?>
<xsl:stylesheetversion="1.0"xmlns:xsl=
"http://www.w3.org/1999/XSL/Transform
">
<xsl:outputmethod ="html" />
<xsl:templatematch="/" >
<html>
<body>
<xsl:apply-templates />
</body>
</html>
</xsl:template>
<xsl:templatematch="CONG_TY" > Danh sách đơn vị :
<select>
<xsl:apply-templates />
</select>
</xsl:template>
<xsl:templatematch="DON_VI" >
<option>
<xsl:value-ofselect =
"@Ten
"/>
</option>
</xsl:template>
</xsl:stylesheet>
* XML --- > thẻ ul,ol
Vấn đề :
Cần xuất danh sách trình bày nội dung và các mục trên trên trang Web từ một nút với nhiều nút con củatập tin Xml trong một ứng dụng Web theo dạng
Nội dung 1
Mục con 11
Mục con 12
....
Xuất nội dung câu hỏi trắc nghiệm
Xuất tổ chức trường -khối - lớp theo dạng cây
....
Hướng giải quyết :
Sử dụng thẻ ul kết hợp li với các mục không có thứ tự
Hay sử dụng thẻ ol kết hợp li với các mục có thứ tự
....
<ul>
<xsl:apply-templates select="Biểu thức Xpath tương ứng danh sách" />
</ul>
.... hay
....
<ol>
<xsl:apply-templates select="Biểu thức Xpath tương ứng danh sách" />
</ol>
....
và
<xsl:template match="Biểu thức Xpath tương ứng một phần tử trong danh sách" >
<li>
Thẻ xử lý kết xuất giá trị
</li>
</xsl:template>
Giả sử đã có tập tin Cau_hoi.xml với nội dung như sau
<?xmlversion="1.0"encoding="utf-8" ?>
<CAU_HOINoi_dung="Nước Việt Nam hình chử gì ?">
<CHON_LUANoi_dung="Chử M" />
<CHON_LUANoi_dung="Chử S" />
<CHON_LUANoi_dung="Chử K" />
<CHON_LUANoi_dung="Chử R" />
</CAU_HOI>
Chương trình Xslt sau sẽ trình bày câu hỏi trên Web
Câu hỏi trắc nghiệm
Nước Việt Nam hình chử gì ? Chử M
Chử S Chử K Chử R
<?xmlversion="1.0"encoding="UTF-8" ?>
<xsl:stylesheetversion="1.0"xmlns:xsl=
"http://www.w3.org/1999/XSL/Transform
">
<xsl:outputmethod ="html" />
<xsl:templatematch="/" >
<html>
<body>
Câu hỏi trắc nghiệm <br />
<xsl:apply-templates />
</body>
</html>
</xsl:template>
<xsl:templatematch="CAU_HOI" >
<ol >
<xsl:value-ofselect =
"@Noi_dung"
/>
<xsl:apply-templates />
</ol>
</xsl:template>
<xsl:templatematch="CHON_LUA" >
<li>
<xsl:value-ofselect =
"@Noi_dung"
/>
</li>
</xsl:template>
</xsl:stylesheet>
Chương trình Xslt sau sẽ trình bày tổ chức các khối lớp của một trường theo dạng cây phân cấp
<?xmlversion="1.0"encoding="UTF-8" ?>
<xsl:stylesheetversion="1.0"xmlns:xsl=
"http://www.w3.org/1999/XSL/Transform
">
<xsl:outputmethod ="html" />
<xsl:templatematch="/" >
<html>
<body>
<xsl:apply-templates />
</body>
</html>
</xsl:template>
<xsl:templatematch="TRUONG" >
<ul >
<xsl:value-ofselect =
"@Ten
" />
<xsl:apply-templates />
</ul>
</xsl:template>
<xsl:templatematch="KHOI" >
<ul >
<xsl:value-ofselect =
"@Ten
" />
<xsl:apply-templates />
</ul>
</xsl:template>
<xsl:templatematch="LOP" >
<ul >
<xsl:value-ofselect =
"@Ten
" />
<xsl:apply-templates />
</ul>
</xsl:template>
</xsl:stylesheet>
* XML -- > Thẻ Table
Vấn đề :
Cần xuất danh sách dạng lưới trên trang Web từ một danh sách các nút của tập tin Xml trong một ứng dụng Web
Xuất danh sách các mặt hàng : tên , Đơn giá
Xuất danh sách các nhân viên : Họ tên , Ngày sinh , Giới tính
Xuất danh sách các môn học : tên môn , Số tiết LT, Số tiết thực hành
....
Hướng giải quyết :
Sử dụng thẻ table , tr, td của ngôn ngữ Html
....
<table>
<xsl:apply-templates select="Biểu thức Xpath tương ứng danh sách" />
</table>
....
<xsl:template match="Biểu thức Xpath tương ứng một phần tử trong danh sách" >
<tr>
<td>
Thẻ xử lý kết xuất giá trị tại cột thứ 1
</td>
<td>
Thẻ xử lý kết xuất giá trị tại cột thứ 12
</td>
.....
</tr>
</xsl:template>
Ví dụ :
Chương trình Xslt sau sẽ xuất bảng đơn giá thuê phòng từ tập tin Bang_don_gia.xml
<?xmlversion="1.0"encoding="UTF-8" ?>
<xsl:stylesheetversion="1.0"xmlns:xsl=
"http://www.w3.org/1999/XSL/Transform
">
<xsl:outputmethod ="html" />
<xsl:templatematch="/" >
<html>
<body>
<divalign="center">
Bảng đơn giá thuê phòng <br />
<xsl:apply-templates />
</div>
</body>
</html>
</xsl:template>
<xsl:templatematch="BANG_DON_GIA" >
<tableborder="2">
<tr>
<td>
Loại phòng
</td>
<td>
Đơn giá
</td>
</tr>
<xsl:apply-templates />
</table>
</xsl:template>
<xsl:templatematch="LOAI_PHONG" >
<tr>
<td>
<xsl:value-ofselect =
"@Ten
"/>
</td>
<td>
<xsl:value-ofselect =
"@Don_gia
"/>
</td>
</tr>
</xsl:template>
</xsl:stylesheet>
Mục tiêu :
Trình bày một số kỹ thuật cơ bản cho phép tạo tài liệu Xml mới dựa trên một tài liệu Xml đã có
- Trích rút thông tin
- Tái cấu trúc
* Tạo nút và thuộc tính
Vấn đề :
Cần tạo thẻ mới X cùng với các thuộc tính trong tập tin xml kết xuất
Hướng giải quyết :
Cách 1 : Tạo lập trực tiếp thẻ mới X trong chương trình Xslt ( tương tự như sao5n thảo tập tin XML Cách 2 : Sử dụng các thẻ xử lý xsl:element , xsl:attribute
Thẻ xsl:element
Ý nghĩa :
Cho phép tạo thẻ mới trong tập tin Xml kết xuất
Cú pháp :
<xsl:element name="Ten_the" >
Các thẻ xử lý tạo thuộc tính ( nếu có ) Các thẻ khác
</xsl:element> Thẻ xsl:attribute
Ý nghĩa :
Cho phép tạo thuộc tính của một thẻ trong tập tin Xml kết xuất
Cú pháp :
<xsl:element name="Ten_the" >
<xsl:attribute name="ten_thuoc_tinh" >
Thẻ xử lý kết xuất giá trị của thuộc tính
</xsl:attribute> Các thẻ khác
</xsl:element>
Chương trình Xslt sau đây biến đổi tập tin Phieu_thu.xml với tập tin Xml kết xuất có các nút con tươngứng các thuộc tính
<?xmlversion="1.0"encoding="utf-8" ?>
<PHIEU_THUKhach_hang="Trần văn Long" Ngay_thu="11/2/2007" So_tien="40000" >
</PHIEU_THU> Chương trình Xslt
<?xmlversion="1.0"encoding="UTF-8" ?>
<xsl:stylesheetversion="1.0"xmlns:xsl=
"http://www.w3.org/1999/XSL/Transform
">
<xsl:outputmethod ="xml"indent="yes" />
<xsl:templatematch="/" >
<xsl:apply-templates />
</xsl:template>
<xsl:templatematch="PHIEU_THU" >
<xsl:variablename="Ngay_thu"select =
"@Ngay_thu"
/>
<xsl:variablename="So_tien"select =
"@So_tien"
/>
<xsl:variablename ="Ten"select =
"@Khach_hang"
/>
<PHIEU_THUNgay_thu="{$Ngay_thu}" So_tien="{$So_tien}">
<KHACH_HANGTen="{$Ten}" />
</PHIEU_THU>
</xsl:template>
</xsl:stylesheet>
* Sao chép nút
Vấn đề :
Cần tạo thẻ kết xuất trong tập tin xml kết xuất có cùng tên và các thuộc tính với thẻ trong tập tin nguồn
Hướng giải quyết :
Cách 1 : Sử dụng các thẻ xử lý xsl:element , xsl:attribute
Cách 2 : Sử dụng các thẻ xử lý xsl:copy , xsl:attribute
Thẻ xsl:copy
Ý nghĩa :
Cho phép sao chép thẻ từ tập tin xml nguồn ( với nút ngữ cảnh tương ứng thẻ ) sang tập tin xml kết xuất
Cú pháp :
<xsl:copy >
Các thẻ xử lý tạo thuộc tính ( nếu có ) Các thẻ khác
</xsl:copy>
Kết hợp với xsl:attribute để sao chép thẻ - thuộc tính
<xsl:copy >
<xsl:for-each select=
"@
*" >
<xsl:attribute name="{name()}" >
<xsl:value-of select="." />
</xsl:attribute>
</xsl:for-each>
</xsl:copy>
Chương trình sau trích danh sách các khối của tập tin truong.xml
<?xmlversion="1.0"encoding="UTF-8" ?>
<xsl:stylesheetversion="1.0"xmlns:xsl=
"http://www.w3.org/1999/XSL/Transform
">
<xsl:outputmethod ="xml"indent="yes" />
<xsl:templatematch="/" >
<xsl:apply-templates />
</xsl:template>
<xsl:templatematch="TRUONG" >
<xsl:copy >
<xsl:attributename="Ten" >
<xsl:value-ofselect=
"@Ten
"/>
</xsl:attribute>
<xsl:apply-templates />
</xsl:copy>
</xsl:template>
<xsl:templatematch="KHOI" >
<xsl:copy >
<xsl:attributename="Ten" >
<xsl:value-ofselect=
"@Ten
"/>
</xsl:attribute>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
Chương trình Xslt sau cho phép biến đổi tập tin Xml bất kỳ theo qui tắc : Tất cả thuộc tính sẽ biến thành thẻ con
<?xmlversion="1.0"encoding="UTF-8" ?>
<xsl:stylesheetversion="1.0"xmlns:xsl=
"http://www.w3.org/1999/XSL/Transform
">
<xsl:outputmethod ="xml"indent="yes" />
<xsl:templatematch="/" >
<xsl:apply-templates />
</xsl:template>
<xsl:templatematch="*" >
<xsl:copy >
<xsl:for-eachselect=
"@*"
>
<xsl:elementname="{name()}" >
<xsl:value-ofselect="."/>
</xsl:element>
</xsl:for-each>
<xsl:apply-templates />
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
* Sao chép nút - thuộc tính - nút con
Vấn đề :
Cần sao chép toàn bộ thẻ X , tất cả thuộc tính của X, tất các thẻ con mọi cấp của X trong tập tin xml nguồn vào tập tin Xml kết xuất
Hướng giải quyết :
Cách 1 : Sử dụng các thẻ xử lý xsl:copy , xsl:attribute
Cách 2 : Sử dụng thẻ xử lý xsl:copy-of
Thẻ xsl:copy-of
Ý nghĩa :
Cho phép sao chép toàn bộ thẻ X , tất cả thuộc tính của X, tất các thẻ con mọi cấp của X trong tập tin xml nguồn vào tập tin Xml kết xuất
Cú pháp :
<xsl:copy-of select="Biểu thức Xpath" />
Cho tập tin xml Bang_phan_cong.xml
<?xmlversion="1.0"encoding="utf-8" ?>
<TRUONGTen="Trường X" >
<MONTen="Toán">
<GIAO_VIENTen="Trần văn Minh" >
<LOPTen="10A1" />
<LOPTen="11A1" />
<LOPTen="12A1" />
</GIAO_VIEN>
<GIAO_VIENTen="Trần văn Lộc" >
<LOPTen="10B1" />
<LOPTen="11B1" />
<LOPTen="12B1" />
</GIAO_VIEN>
<GIAO_VIENTen="Trần văn Hùng" >
<LOPTen="10B2" />
<LOPTen="11A3" />
<LOPTen="12B2" />
</GIAO_VIEN>
</MON>
<MONTen="Lý">
<GIAO_VIENTen="Lê văn Sơn" >
<LOPTen="10A1" />
<LOPTen="11B1" />
<LOPTen="12C1" />
</GIAO_VIEN>
<GIAO_VIENTen="Nguyễn thị bé Nhỏ" >
<LOPTen="10B1" />
<LOPTen="11B2" />
<LOPTen="12B1" />
</GIAO_VIEN>
</MON>
<MONTen="Hóa">
<GIAO_VIENTen="Ngô thị Bích" >
<LOPTen="10B1" />
<LOPTen="11B1" />
<LOPTen="12C1" />
</GIAO_VIEN>
<GIAO_VIENTen="Lê văn Lớn" >
<LOPTen="10A1" />
<LOPTen="12B1" />
</GIAO_VIEN>
<GIAO_VIENTen="Đổ thị Tuyết" >
<LOPTen="10B2" />
<LOPTen="11A3" />
<LOPTen="12B2" />
</GIAO_VIEN>
</MON>
<MONTen="Sinh">
<GIAO_VIENTen="Nguyễn hùng Cường">
<LOPTen="10A1" />
<LOPTen="11A1" />
<LOPTen="12A1" />
</GIAO_VIEN>
<GIAO_VIENTen="Lê văn Tùng" >
<LOPTen="11A2" />
<LOPTen="12B1" />
</GIAO_VIEN>
<GIAO_VIENTen="Nguyễn thị Đẹp" >
<LOPTen="11B2" />
<LOPTen="11A3" />
<LOPTen="11B3" />
</GIAO_VIEN>
</MON>
</TRUONG>
Đoạn chương trình sau cho phép tái cấu trúc tập tin Bang_phan_cong.xml với thẻ MON chuyễn thành thuộc tính Bo_mon của thẻ GIAO_VIEN
<?xmlversion="1.0"encoding="UTF-8" ?>
<xsl:stylesheetversion="1.0"xmlns:xsl=
"http://www.w3.org/1999/XSL/Transform
">
<xsl:outputmethod ="xml"indent="yes" />
<xsl:templatematch="/" >
<xsl:apply-templates />
</xsl:template>
<xsl:templatematch="TRUONG" >
<xsl:copy >
<xsl:attributename="Ten" >
<xsl:value-ofselect=
"@Ten
"/>
</xsl:attribute>
<xsl:apply-templates />
</xsl:copy>
</xsl:template>
<xsl:templatematch="GIAO_VIEN" >
<xsl:copy >
<xsl:attributename="Ten" >
<xsl:value-ofselect=
"@Ten
"/>
</xsl:attribute>
<xsl:attributename="Bo_mon" >
<xsl:value-ofselect="..
/@Ten
"/>
</xsl:attribute>
<xsl:copy-ofselect="LOP"/>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
* Sắp thứ tự các nút
Vấn đề :
Cần sắp thứ tự danh sách các thẻ X của tập tin xml kết xuất
Hướng giải quyết :
Sử dụng thẻ xử lý xsl:sort kết hợp với xsl:apply-templates
Thẻ xsl:sort
Ý nghĩa :
Cho phép sắp thứ tự danh sách các thẻ X của tập tin xml kết xuất
Cú pháp : Sắp tăng
<xsl:sort order="accending" select="Thuộc tính" /> Sắp giảm
<xsl:sort order="descending" select="Thuộc tính" />
Kết hợp với xsl:apply-templates để tiến hành sắp thứ tự các kết quả sau khi thực hiện so khớp các hàm/mẩu
<xsl:apply-templates select="Biểu thức Xpath" >
<xsl:sort order="...." select="...." />
<xslsort order="...." select="...." />
......
</xsl:aplly-templates>
Với tập tin Xml Ket_qua_Olympic.xml
<?xmlversion="1.0"encoding="utf-8" ?>
<KET_QUA>
<QUOC_GIATen="AAA"So_vang="10"So_bac="7"So_dong="2" />
<QUOC_GIATen="XXX"So_vang="6"So_bac="0"So_dong="12" />
<QUOC_GIATen="BBB"So_vang="10"So_bac="8"So_dong="13" />
<QUOC_GIATen="DDD"So_vang="4"So_bac="17"So_dong="0" />
<QUOC_GIATen="MMM"So_vang="6"So_bac="1"So_dong="0" />
<QUOC_GIATen="KKK"So_vang="6"So_bac="0"So_dong="2" />
<QUOC_GIATen="LLL"So_vang="10"So_bac="4"So_dong="23" />
<QUOC_GIATen="PPP"So_vang="3"So_bac="27"So_dong="100" />
</KET_QUA>
Đoạn chương trình XSL sau sắp xếp các quốc gia giảm dần theo thứ tự ưu tiên
- Ứu tiên 1 : Số huy chương vàng
- Ứu tiên 2 : Số huy chương bạc
- Ưu tiên 3 : Số huy chương đồng
<?xmlversion="1.0"encoding="UTF-8" ?>
<xsl:stylesheetversion="1.0"xmlns:xsl=
"http://www.w3.org/1999/XSL/Transform
">
<xsl:outputmethod ="xml"indent="yes" />
<xsl:templatematch="/" >
<xsl:apply-templates />
</xsl:template>
<xsl:templatematch="KET_QUA" >
<xsl:copy >
<xsl:apply-templates select ="QUOC_GIA">
<xsl:sort order="descending"data-type="number"select=
"@So_vang"
/>
<xsl:sort order="descending"data-type="number"select=
"@So_bac
" />
<xsl:sort order="descending"data-type="number"select=
"@So_dong"
/>
</xsl:apply-templates>
</xsl:copy>
</xsl:template>
<xsl:templatematch="QUOC_GIA" >
<xsl:copy >
<xsl:copy-ofselect =
"@*
"/>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
XML --- > HTML
* Tích 2 phân số
Yêu cầu :
Viết chương trình XSLT cho phép tạo kết xuất từ dữ liệu nguồn
- Dữ liệu nguồn : Tập tin xml biểu diễn thông tin về 2 phân số
- Kết xuất : Trang Web thể hiện kết quả nhân 2 phân số
với phân số 4/7, 5/11
Kết xuất sẽ là
Kết quả tính tích 2 phân số 1/7 và 5/11
4/7*5/11=20/77
* Phương trình đường thẳng
Yêu cầu :
Viết chương trình XSLT cho phép tạo kết xuất từ dữ liệu nguồn
- Dữ liệu nguồn : Tập tin xml biểu diễn thông tin về các hệ số của phương trình đường thẳng trong mặt phẳng
- Kết xuất : Trang Web thể hiện kết quả là phương trình đường thẳng
Với giá trị các hệ số 2,3,4
Kết xuất sẽ là : Phương trình đường thẳng 2x + 3y + 4=0
Vời giá trị các hệ số 7,-3
Kết xuất sẽ là : Phương trình đường thẳng 7x - 3y =0
* Phương trình đường tròn
Yêu cầu :
Viết chương trình XSLT cho phép tạo kết xuất từ dữ liệu nguồn
- Dữ liệu nguồn : Tập tin xml biểu diễn thông tin về tọa độ tâm và bán kính của một đường tròn
- Kết xuất : Trang Web thể hiện kết quả là phương trình đường tròn
Với giá trị các tọa độ tâm 4,5 và bán kính 3
Kết xuất sẽ là : Phương trình đường tròn (x−4)2 size 12{ ( x - 4 ) rSup { size 8{2} } } {}+ (y−5)2 size 12{ ( y - 5 ) rSup { size 8{2} } } {}= 9
Với giá trị các tọa độ tâm -2,3 và bán kính 7
Kết xuất sẽ là : Phương trình đường tròn (x+2)2 size 12{ ( x+2 ) rSup { size 8{2} } } {}+ (y−3)2 size 12{ ( y - 3 ) rSup { size 8{2} } } {}= 49
* Đề trắc nghiệm
Yêu cầu :
Viết chương trình XSLT cho phép tạo kết xuất từ dữ liệu nguồn
- Dữ liệu nguồn : Tập tin xml biểu diễn thông tin về đề trắc nghiệm
- Kết xuất : Trang Web thể hiện đề trắc nghiệm
* Hồ sơ học sinh
Yêu cầu :
Viết chương trình XSLT cho phép tạo kết xuất từ dữ liệu nguồn
- Dữ liệu nguồn : Tập tin xml biểu diễn thông tin về hồ sơ học sinh bao gồm : Họ và tên , giới tính, ngày sinh , địa chỉ
- Kết xuất :
a) Trang Web thể hiện hồ sơ học sinh dạng xem
b) Trang Web thể hiện hồ sơ học sinh dạng nhập liệu ( cập nhật)
* Bảng xếp hạng Olympic
Yêu cầu :
Viết chương trình XSLT cho phép tạo kết xuất từ dữ liệu nguồn
- Dữ liệu nguồn : Tập tin xml biểu diễn thông tin kết quả thi đấu Olympic các quốc gia
- Kết xuất :
a) Trang Web thể hiện bảng kết quả thi đấu
b) Trang Web cho phép cập nhật số huy chương vàng, bạc, đồng
XML - XML
* Hồ sơ nhân viên
Yêu cầu :
Viết chương trình XSLT cho phép tạo kết xuất từ dữ liệu nguồn
- Dữ liệu nguồn : Tập tin xml biểu diễn thông tin về hồ sơ nhân viên với
+ Thông tin bao gồm : Họ và tên, Giới tính , Ngày sinh, Địa chỉ , Đơn vị
+ Tất cả các thông tin đều biểu diễn dưới dạng thẻ con
- Kết xuất : Tập tin Xml
a) Tất cả các thông tin đều biểu diễn dạng thuộc tính
b) Tất cả các thông ngoại trừ đơn vị đều biểu diễn dạng thuộc tính
* Trường - khối - lớp
Yêu cầu :
Viết chương trình XSLT cho phép tạo kết xuất từ dữ liệu nguồn
- Dữ liệu nguồn : Tập tin xml biểu diễn thông tin tổ chức trường , các khối của trường, các lớp của khối
- Kết xuất :
a) Tập tin Xml chỉ bao gồm các lớp có sỉ số trên 30
b) Tập tin Xml chỉ bao gồm các khối có hơn 5 lớp
* Bảng phân công giáo viên
Yêu cầu :
Viết chương trình XSLT cho phép tạo kết xuất từ dữ liệu nguồn
- Dữ liệu nguồn : Tập tin xml biểu diễn thông tin bảng phân công các giáo viên của một trường
- Kết xuất :
a) Tập tin Xml chỉ bao gồm danh sách các bộ môn cùng với số lượng các giáo viên
b) Tập tin Xml chỉ bao gồm danh sách các giáo viên được phân công dạy trên 2 lớp
* Cây số nguyên
Yêu cầu :
Viết chương trình XSLT cho phép tạo kết xuất từ dữ liệu nguồn
- Dữ liệu nguồn : Tập tin xml biểu diễn thông tin cây các số nguyên
- Kết xuất :
a) Tập tin Xml chỉ bao gồm danh sách các nút lá
b) Tập tin Xml chỉ bao gồm danh sách các nút có giá trị từ 1 đến 10
c) Tập tin Xml là tập tin nguồn sau khi bỏ đi các nút lá
d) Tập tin Xml là tập tin nguồn sau khi bỏ đi tất cả các nút con cấp 1 ( con của gốc )
e) Tập tin Xml là tập tin nguồn sau khi sắp thứ tự tăng các nút cùng cha