peri hokiperihokiclarustologisticsrimashaop.compola taktis menang gates of olympus x1000 perihokipemain perihoki bongkar trik jepep starlight princess x1000perihoki beri panduan lengkap bermain mahjong ways 2 pgsofttips cara penghasil uang pgsoft mahjong ways 2 perihokimahjong wins 3 perihoki memberikan penggali terbesarfenomena gates of olympus buka peluang besar bagi duta76cara dapat pola emas rahasia di duta7 wild west goldtrik menang pgsoft mahjong ways 2 modal receh maxwin duta76duta76 main pgsoft mahjong ways 2 di sela istirahatscatter hitam mahjong wins 3 spin pasti jepe duta76perihoki spin mahjong ways 2 pgsoft scatter hitam maxwinsimbol mahjong wins 3 yang sering muncul di awal perihokitrik gampang menang mahjong winscuan mahjong wins 3 tanpa hentipola spin taruhan kecil mahjong winsstrategi kunci scatter hitam beruntungacor total mahjong wayskemenangan maksimal mahjong wayskemenangan pria pekanbaru mahjong waysmahjong wins3 fenomena baru sumatera baratmenangkan mahjong dengan lincahmenembus batas keberuntungan mahjong waysmenjajal keberuntungan di mahjong wayspola gratis mahjong ways1scatter hitam senjata rahasia mahjong winsteknik spinning menguntungkan untuk scatter hitamanalisis rtp tertinggi mahjong winsfenomena scatter hitam mahjong winsibu rumah tangga dan keberuntungan mahjongkeseruan main mahjong wins3menang mahjong pengguna baru di sosial mediamenghargai setiap momen di mahjong waysserunya main mahjong di warung internetspin slow motion mancing scatterstrategi jitu maxwin mahjong waysstrategi jitu menang mahjong modal kecil jackpot besaranak kampung papua menggemparkan mahjongkeajaiban scatter hitam mahjong wayskeberhasilan joni mahjong winskejaiban mahjong ways di ujung jalanketua mahjong wins3 kehadiran kemenangan dimulai dari balimahjong kehadiran yang menguntungkanmahjong menggila adat88panduan kilat raih 108 jutatips memenangkan mahjongbarista kopi menang 110 juta spin mahjongdakota76 scatter hitam mahjong wins 3gagal cpns menang mahjong wins 3 rp120 jutakisah karyawan minimarket dapat thr lebih awal mahjong winskisah pelajar sma kuasai mahjong wins 3 inspirasi sekolahkisah penjaga parkir tanah abang motor baru mahjong winskisah sukses ibu rumah tangga bandung mahjong winsmahasiswa kkn beli iphone15 mahjong wins3 dakotamantan anak band influencer mahjong scatter hitampola rtp senin gates of olympus guru matematikaidola scatter hitam gampang meledakidola sensasi jackpotidola pola scatter hitamidola hasilkan jackpot dalam waktu singkatidola mahjong wins 3 bocortukang cuci motor menemukan keberuntungan di mahjong

A PHP Error was encountered

Severity: Warning

Message: ini_set(): Headers already sent. You cannot change the session module's ini settings at this time

Filename: Session/Session.php

Line Number: 282

Backtrace:

File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct

File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once

File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once

A PHP Error was encountered

Severity: Warning

Message: session_set_cookie_params(): Cannot change session cookie parameters when headers already sent

Filename: Session/Session.php

Line Number: 294

Backtrace:

File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct

File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once

File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once

A PHP Error was encountered

Severity: Warning

Message: ini_set(): Headers already sent. You cannot change the session module's ini settings at this time

Filename: Session/Session.php

Line Number: 304

Backtrace:

File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct

File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once

File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once

A PHP Error was encountered

Severity: Warning

Message: ini_set(): Headers already sent. You cannot change the session module's ini settings at this time

Filename: Session/Session.php

Line Number: 314

Backtrace:

File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct

File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once

File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once

A PHP Error was encountered

Severity: Warning

Message: ini_set(): Headers already sent. You cannot change the session module's ini settings at this time

Filename: Session/Session.php

Line Number: 315

Backtrace:

File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct

File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once

File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once

A PHP Error was encountered

Severity: Warning

Message: ini_set(): Headers already sent. You cannot change the session module's ini settings at this time

Filename: Session/Session.php

Line Number: 316

Backtrace:

File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct

File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once

File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once

A PHP Error was encountered

Severity: Warning

Message: ini_set(): Headers already sent. You cannot change the session module's ini settings at this time

Filename: Session/Session.php

Line Number: 317

Backtrace:

File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct

File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once

File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once

A PHP Error was encountered

Severity: Warning

Message: ini_set(): Headers already sent. You cannot change the session module's ini settings at this time

Filename: Session/Session.php

Line Number: 375

Backtrace:

File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct

File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once

File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once

A PHP Error was encountered

Severity: Warning

Message: ini_set(): Headers already sent. You cannot change the session module's ini settings at this time

Filename: drivers/Session_files_driver.php

Line Number: 108

Backtrace:

File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct

File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once

File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once

A PHP Error was encountered

Severity: Warning

Message: session_set_save_handler(): Cannot change save handler when headers already sent

Filename: Session/Session.php

Line Number: 110

Backtrace:

File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct

File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once

File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once

A PHP Error was encountered

Severity: Warning

Message: session_start(): Cannot start session when headers already sent

Filename: Session/Session.php

Line Number: 143

Backtrace:

File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct

File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once

File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once

Đối tượng Workbook và Worksheet trong VBA - Freetuts
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.

test php

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.

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.

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".

Bài viết này được đăng tại [free tuts .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