MACRO
EXCEL OBJECT
VBA BASIC
VBA FORM
BÀI TẬP
CÁC CHỦ ĐỀ
BÀI MỚI NHẤT
MỚI CẬP NHẬT

Cách dùng Workbook và Worksheet trong VBA

Trong bài này chúng ta sẽ tìm hiểu hai đối tượng Workbook và Worksheet trong VBA, qua bài này bạn sẽ hiểu được sự phân cấp của hai khái niệm Workbook và Worksheet được sử dụng trong VBA như thế nào.

Trước tiên hãy chắc chắn rằng bạn đã biết cách viết một Macro trong VBA nhé, bởi kể từ bài này mình sẽ không nói thêm về cách chạy một chương trình VBA.

banquyen png
Bài viết này được đăng tại freetuts.net, không được copy dưới mọi hình thức.

1. Phân cấp các đối tượng Excel trong VBA

Để làm việc với Excel thì VBA đã tạo sẵn ra các đối tượng giúp lập trình viên có thể giao tiếp với các file, bảng tính và các ô trong Excel.

  • Level 1: Cấp cao nhất chính là ứng dụng Excel, ta gọi là đối tượng Application.
  • Level 2: Excel cho bạn mở nhièu file khác nhau, và mỗi file ta gọi là Workbook.
  • Level 3: Mỗi file Excel (Workbook) có thể có nhiều bảng tính (sheet), và ta gọi nó là Worksheet.
  • Level 4: Trong mỗi bảng tính thì có nhiều ô, và mỗi vùng chọn dữ liệu ta gọi là một Range (ta sẽ học ở bài tiếp theo)

Ví dụ: Đoạn code thiết lập giá trị cho ô A1 là "Hi Freetuts.net".

Range("A1").Value = "Hello"

Khi chạy đoạn code này thì VBA tự hiểu là ô A1 sẽ nằm ở Workbook và Sheet mà bạn đang làm việc.

Giả sử mình mở nhiều file Excel và có nhiều sheet thì cú pháp của nó sẽ có dạng như sau:

Application.Workbooks("excel-example").Worksheets(1).Range("A1").Value = "Hi Freetuts.net"

Như vậy, các level sẽ được ngăn cách nhau bởi dấu chấm .. Như trong ví dụ trên thì mình đã chọn ô A1 nằm trong sheet 1 của file excel-example.xlsm.

* Lưu ý: Bạn phải thực hiện theo đúng thứ tự các cấp nhé, từ Object cha mới lấy được Object con.

2. Collections Object VBA

Bạn có thể nhận thấy rằng Workbooks và Worksheets đều ở dạng số nhiều (có s). Đó là bởi vì chúng là những bộ sưu tập (collections). Bộ sưu tập Workbooks chứa tất cả các đối tượng Workbook hiện đang mở. Bộ sưu tập Worksheets chứa tất cả các đối tượng Worksheet trong workbook.

Giả sử mình đang mở một file Excel tên là company.xlsm có cấu trúc các sheet như sau:

worksheet names png

Trong ví dụ này thì:

  • Có 1 Workbook tên là company
  • Trong workbook company có 3 worksheets gồm: Sales, ProductionLogistics.

Bạn có thể tham chiếu đến các ô (Range) ở bên trong một trang tính nào đó thì có 3 cách thực hiện như sau:

Cách 1: Sử dụng worksheet name

Worksheets("Sales").Range("A1").Value = "Hello"

Cách 2: Sử dụng số thứ tự của worksheet

Worksheets(1).Range("A1").Value = "Hello"

Cách 3: Sử dụng CodeName

Sheet1.Range("A1").Value = "Hello"

CodeName có lẽ là khái niệm mới đối với bạn nên mình sẽ giải thích nhé.

  • Khi bạn tạo một file Excel trống thì mặc định nó sẽ có một Sheet tên là Sheet1, và CodeName của sheet này là Sheet1.
  • Bạn tạo thêm một sheet nữa thì tên mặc định là Sheet2, CodeName là Sheet2.
  • ... Cứ như vậy, số thứ tự nó sẽ tăng theo số lần tạo của bạn.

Tuy nhiên bạn cần phải lưu ý rằng:

  • Khi bạn đổi tên của sheet thì CodeName của nó vẫn giữ nguyên nhé.
  • Thứ tự bạn sắp xếp các sheet ở bên ngoài Excel không liên quan đến CodeName, nghĩa là CodeName sẽ tham chiếu đến đúng đến sheet mà bạn đã tạo.

Để xem kỹ hơn thì bạn hãy mở Visual Basic Editor lên thì thấy nó có cách file VBA như sau:

codename png

Vì vậy, để an toàn hơn thì bạn nên vào đây để xem CodeName nhé.

3. Các phương thức của Workbook và Worksheet

Bây giờ ta sẽ làm một ví dụ nhé. Bạn hãy tạo một Button và khi click vào button đó thì chạy những đoạn code dưới đây.

Đoạn code 1: Thêm một Workbook vào không gian làm việc.

Workbooks.Add

Phương thức Add sẽ thêm một workbook và trong workbook đó sẽ có một worksheet.

Đoạn code 2: Đếm tổng số Workbooks đang có.

MsgBox Worksheets.Count

Để xem đầy đủ các phương thức và thuộc tính thì bạn hãy nhập Workbooks. thì VBA sẽ xổ ra một list cho bạn chọn.

show list workbooks JPG

Tương tự, gõ Worksheets. thì các thuộc tính của worksheet cũng xổ ra:

show list worksheets JPG

Qua bài này mình đã giới thiệu xong hai đối tượng Workbooks và Worksheets trong Excel VBA rồi phải không nào? Đây là hai đối tượng được sử dụng rất nhiều, vì vậy bạn phải hiểu mối liên hệ của nó trong VBA để sau này lập trình cho chuẩn xác hơn.

Cùng chuyên mục:

Cách chèn link ảnh vào Excel trên máy tính

Cách chèn link ảnh vào Excel trên máy tính

Ngoài ra, bài viết còn hướng dẫn cách chèn link ảnh trực tuyến hàng loạt…

Cách tách và gộp ô trong Excel

Cách tách và gộp ô trong Excel

Trong bảng tính Microsoft Excel, có thể sẽ có lúc các bạn cần tách ô…

Hàm MONTH() trong Excel

Hàm MONTH() trong Excel

Cách dùng hàm MONTH() trong Excel

Hàm YEAR () trong Excel

Hàm YEAR () trong Excel

Cách dùng hàm YEAR () trong Excel

Hàm HLOOKUP() trong Excel

Hàm HLOOKUP() trong Excel

Cách dùng hàm HLOOKUP() trong Excel

Hàm VLOOKUP() trong Excel

Hàm VLOOKUP() trong Excel

Cách dùng hàm VLOOKUP() trong Excel

Hàm LOOKUP() trong Excel

Hàm LOOKUP() trong Excel

Cách dùng hàm LOOKUP() trong Excel

Hàm ABS() trong Excel

Hàm ABS() trong Excel

Cách dùng hàm ABS() trong Excel

Hàm SUM() trong Excel

Hàm SUM() trong Excel

Cách dùng hàm SUM() trong Excel

Hàm SQRT() trong Excel

Hàm SQRT() trong Excel

Cách dùng hàm SQRT() trong Excel

Hàm MOD() trong Excel

Hàm MOD() trong Excel

Cách dùng hàm MOD() trong Excel

Hàm SUMIF() trong Excel

Hàm SUMIF() trong Excel

Cách dùng hàm SUMIF() trong Excel

Hàm SUBTOTAL() trong Excel

Hàm SUBTOTAL() trong Excel

Cách dùng hàm SUBTOTAL() trong Excel

Hàm ROUND() trong Excel

Hàm ROUND() trong Excel

Cách dùng hàm ROUND() trong Excel

Hàm SUMPRODUCT() trong Excel

Hàm SUMPRODUCT() trong Excel

Cách dùng hàm SUMPRODUCT() trong Excel

Hàm COUNT() trong Excel

Hàm COUNT() trong Excel

Cách dùng hàm COUNT() trong Excel

Hàm COUNTA() trong Excel

Hàm COUNTA() trong Excel

Cách dùng hàm COUNTA() trong Excel

Hàm COUNTBLANK() trong Excel

Hàm COUNTBLANK() trong Excel

Cách dùng hàm COUNTBLANK() trong Excel

Hàm MAX() trong Excel

Hàm MAX() trong Excel

Cách dùng hàm MAX() trong Excel

Hàm MIN() trong Excel

Hàm MIN() trong Excel

Cách dùng hàm MIN() trong Excel

Top