XPath với Selenium trong WPF

Khóa học Selenium cơ bản đến nâng cao

5.0 (1 đánh giá)
Tạo bởi K9 Cập nhật lần cuối 3 năm trước 24.563 lượt xem 7 bình luận
Tác giả/Dịch giả: K9
Học nhanh

Danh sách bài học

XPath với Selenium trong WPF

Dẫn nhập

Trong bài trước, Kteam đã giới thiệu đến bạn WEBELEMENT TRONG SELENIUM.

Ở bài này, chúng ta sẽ tìm hiểu khái niệm XPath với Selenium trong WPF.


Nội dung

Để đọc hiểu bài này tốt nhất bạn cần:

Bạn và Kteam sẽ cùng tìm hiểu những nội dung sau đây

  • XPath trong Selenium là gì?
  • CssSelector trong Selenium

Xpath trong Selenium là gì?

Ở các bài trước chúng ta đã có thể lấy ra các Element trong Selenium một cách dễ dàng bằng phương thức find. Nhưng vẫn có hạn chế đó là có Element không có Id, classname không lấy được, không có tagname…

Vậy để lấy Element đó chúng ta làm sao? Có một thủ thuật đó là dùng JavaScript. Nhưng ta lại muốn lấy đích thị nó ra để dùng. Lúc này XPath ra tay.

Thật ra XPath cũng không khác gì Id hay classname. Chỉ là XPath có thể giúp ta xác định một Element thông qua trật tự của các thuộc tính.

Chúng ta đều biết các thẻ trong HTML đều có sự liên quan đến nhau như thẻ này bên trong thẻ kia, thẻ này là thẻ con thứ n của thẻ kia. Thẻ này ngay sau thẻ kia….

Lợi dụng tính chất đó ta hoàn toàn có thể xác định chính xác một thẻ dựa vào trật tự duy nhất đó. Đó chính là XPath.

XPath có nhiều kiểu cấu trúc. Nhưng đều theo thứ tự từ lớn đến nhỏ. Mình có 2 đoạn XPath cùng chỉ một đối tượng button Bắt đầu học tại website Howkteam.com như sau:

  • XPath copy từ Firefox
  • XPath copy từ Chrome

Hai đoạn này thật ra đều chỉ tới 1 đối tượng, chỉ là hai trường phái khác nhau. Với Firefox thì đúng là thứ tự các Element. Còn Chrome thì tìm thằng gần đó nhất có thể xác định rồi đi tiếp. Cái này mình không cần nói kỹ vì cách để có đoạn XPath này rất dễ.

  • F12 tìm đến đoạn HTML bạn muốn hoặc nhấp phải chọn InspectElement hay Kiểm tra phần tử. Sau đó chọn Copy > Copy XPath. Tùy theo bạn dùng Firefox hay Chrome mà có các đoạn XPath ở các trường phái khác nhau.

Nói lan man mãi vậy XPath này sài thế nào? Thật sự rất đơn giản. Chỉ cần thay XPath bằng id hay classname là xong. Nhưng nên nhớ dùng hàm khác. Đó là: 

FindElementByXPath(“Xpath của bạn lấy được”);

Chỉ đơn giản như vậy thôi.

Code mẫu thử nghiệm

Lưu ý: Chuỗi XPath mình biến nó thành

//*[@id=\"widthdisplay\"]/a[1]/input

  • Có dấu \ trước dấu vì nằm trong chuỗi.

Cùng xem kết quả nhé!

Trình duyệt tự tìm tới nút Bắt đầu học và nhấn vào nó. Quá tuyệt vời luôn!

Vậy là tới đây có vẻ như ta đã có thể bắt được mọi Element mà ta cần nhỉ?


CssSelector trong Selenium

XPath thì tuyệt vời quá! Nhưng đôi khi có những Element rõ ràng XPath đó nhưng lại không lấy được. Lúc này, có một phương pháp thay thế đó là CssSelector.

Cách thức lấy ra CssSelector như thế nào? Tương tự XPath thôi! Chỉ là thay vì tìm theo cấu trúc trật tự của HTML thì tìm theo các CSS của HTML. Thay vì copy XPath thì copy CssSelector. Còn cách dùng thì dùng hàm 

FindElementByCssPath(“Css Path bạn lấy ra được”);

Với button Bắt đầu học thì CssSelector mình lấy được là:

Code mẫu:

Cùng chạy và xem kết quả nhé!

Quá đơn giản đúng không nào?


Kết luận

Bài viết này đã sơ lược cho các bạn cách dùng XPath và CssSelector trong Selenium rồi. Đánh bay mọi rào cản nhỉ?

Ở bài sau, Kteam sẽ nói về PROFILE TRONG SELENIUM.

Cảm ơn bạn đã theo dõi bài viết. Hãy để lại bình luận hoặc góp ý của mình để phát triển bài viết tốt hơn. Đừng quên “Luyện tập – Thử thách – Không ngại khó!


Tải xuống

Tài liệu

Nhằm phục vụ mục đích học tập Offline của cộng đồng, Kteam hỗ trợ tính năng lưu trữ nội dung bài học XPath với Selenium trong WPF dưới dạng file PDF trong link bên dưới.

Ngoài ra, bạn cũng có thể tìm thấy các tài liệu được đóng góp từ cộng đồng ở mục TÀI LIỆU trên thư viện Howkteam.com

Đừng quên likeshare để ủng hộ Kteam và tác giả nhé!

Project

Nếu việc thực hành theo hướng dẫn không diễn ra suôn sẻ như mong muốn. Bạn cũng có thể tải xuống PROJECT THAM KHẢO ở link bên dưới!


Thảo luận

Nếu bạn có bất kỳ khó khăn hay thắc mắc gì về khóa học, đừng ngần ngại đặt câu hỏi trong phần bên dưới hoặc trong mục HỎI & ĐÁP trên thư viện Howkteam.com để nhận được sự hỗ trợ từ cộng đồng.

Tác giả/Dịch giả

K9

Nhà sáng lập Howkteam.com, KQuiz.vn & tác giả các khóa học C#, Auto, Unity3D, Python....

Với mong muốn mang đến kiến thức chất lượng, miễn phí cho mọi người, với tâm huyết phá bỏ rào cản kiến thức từ việc giáo dục thu phí. Tôi đã cùng đội ngũ Kteam đã lập nên trang website này để thế giới phẳng hơn.
Hãy cùng chúng tôi lan tỏa kiến thức đến cộng đồng! 

Khóa học

Khóa học Selenium cơ bản đến nâng cao

Serial này dành cho các bạn muốn học, tìm hiểu về lập trình tools (chương trình tự động) tạo account google, facebook, tools tự động offer, tool tự động mua coin ICO, và nhiều tool tự động khác tùy theo nhu cầu riêng.

Về mặt cơ bản, cấu trúc selenium rất đơn giản nên những người không rành code cũng có thể thao tác. Tuy nhiên để tạo ra các sản phẩm hoàn chỉnh, có chức năng ổn thì cần kiến thức lập trình cơ bản, HTML, CSS và JavaScript…

Trong khóa học này Kteam sẽ giới thiệu đến các bạn một công cụ mạnh mẽ giúp bạn tạo ra các Script tự động thao tác với Web browers – Đó chính là Selenium

Thông qua khóa học LẬP TRÌNH SELENIUM, Kteam sẽ hướng dẫn các bạn những thao tác cơ bản với Selenium. Bạn hoàn toàn có thể kết hợp Selenium và các code C#, Java, Python hay ngôn ngữ lập trình khác mà Selenium có thư viện hỗ trợ, để tạo ra một tổ hợp thao tác kinh khủng khiếp cho tool của bạn.

Đánh giá

Vo Tan Duc đã đánh giá 3 năm trước

Bình luận

Để bình luận, bạn cần đăng nhập bằng tài khoản Howkteam.

Đăng nhập
tuongle đã bình luận 4 năm trước

OpenQA.Selenium.ElementNotInteractableException: 'Element <a class="btn btn-square btn-hero btn-warning text-dark min-width-75 mr-10 mb-10" href="/course/bai-tap-python-tu-luyen/tra-ve-so-nguyen-tao-tu-cac-phan-tu-trong-tuple-truyen-vao-tham-so-la-tuple-phan-tu-chu-so-4215"> could not be scrolled into view'

ad ơi, mỗi lần run nó báo lỗi này tại button.Click() đó ạ, không ra page tự click button như ad, ad giúp em fix lỗi này với ạ

hai2k1 đã bình luận 5 năm trước

ai chỉ em với lấy Xpath nó ra thế này //*[@id="2601491966833063"]/button nhưng id là id random lên chạy nó lại đổi làm thế nào để thay thế ạ

quangcha đã bình luận 5 năm trước

Khi mà không tìm thấy element thì chương trình báo lỗi. Giờ e muốn không tìm thấy element thì bỏ qua thì làm sao AD. 

Trọng Nghĩa đã bình luận 7 năm trước

Đừng bao giờ dùng Chrome lấy XPath, FIrefox sẽ đảm bảo chương trình của bạn chạy ổn từ đầu đến cuối :))

Không có video.