HÀM TRẢ VỀ LỖI TRONG VBA

Một phần của tài liệu Lịch sử máy tính (Trang 181 - 183)

- Giải thích

12.2HÀM TRẢ VỀ LỖI TRONG VBA

CHƯƠNG TRÌNH

12.2HÀM TRẢ VỀ LỖI TRONG VBA

Trong một số trường hợp, hàm có thể sẽ phải trả về một giá trị lỗi nào đó. Để làm rõ hơn điều này, lấy ví dụ hàm phân loại sinh viên.

Function PhanLoai(DiemTB) As String If (DiemTB >= 5) Then

PhanLoai = "Do" Exit Function End If

Exit Function End If

End Function

Hàm này lấy tham số đầu vào để phân loại là điểm trung bình của sinh viên thông qua biến DiemTB với thang điểm 10. Hàm sẽ trả về giá trị kiểu chuỗi: “Đỗ” nếu điểm trung bình lớn hơn hoặc bằng 5, và ngược lại là “Trượt”.

Tuy nhiên, với những trường hợp điểm trung bình, vì một lý do nào đó, được nhập vào giá trị nhỏ hơn 0 hoặc lớn hơn 10 thì hàm vẫn trả về thông báo “Trượt” hoặc “Đỗ”. Như vậy là không hợp lý. Trong những trường hợp đó, cần phải trả về thông báo cho người sử dụng biết là không thể áp dụng hàm với điểm trung bình như vậy. Như vậy, hàm sẽ được thay đổi lại như sau:

Function PhanLoai(DiemTB) As String

If (DiemTB < 0) Or (DiemTB > 10) Then PhanLoai = “#N/A” Exit Function End If If (DiemTB >= 5) Then PhanLoai = "Do" Exit Function End If If (DiemTB < 5) Then PhanLoai = "Truot" Exit Function End If End Function

Và như vậy, kể từ lúc này, mỗi khi vô tình nhập các giá trị điểm không thích hợp, hàm sẽ trả về một thông báo lỗi là “#N/A”. Mặc dù trông rất giống lỗi trong Excel, nhưng thực chất đây vẫn chỉ là một chuỗi thông thường.

Để trả về giá trị lỗi thực sự, VBA đã cung cấp thêm một hàm tên là CVErr, hàm này sẽ chuyển đổi một số thành một giá trị lỗi tương ứng. Với giá trị lỗi thực sự như thế, tất cả những hàm có tham chiếu ô chứa giá trị lỗi cũng sẽ trả về giá trị lỗi như thế. Và như vậy, người dùng chỉ cần thay đổi câu lệnh PhanLoai = “#N/A” bằng câu lệnh PhanLoai = CVErr(xlErrNA). Cần lưu ý là kiểu trả về của hàm CVErr là kiểu Variant, do vậy cũng cần phải thay đổi kiểu giá trị trả về của hàm là

Variant.

Function PhanLoai(DiemTB) As Variant

If (DiemTB < 0) Or (DiemTB > 10) Then

PhanLoai = CVErr(xlErrNA) Exit Function End If If (DiemTB >= 5) Then PhanLoai = "Do" Exit Function End If If (DiemTB < 5) Then PhanLoai = "Truot" Exit Function End If End Function

CHÚ Ý Để sử dụng hàm trả về thông báo lỗi, có sử dụng hàm CVErr, người dùng

phảikhai báo kiểu dữ liệu trả về của hàm là kiểu Variant.

Và như vậy, mỗi khi giá trị đầu vào không đúng, hàm sẽ trả về giá trị lỗi, giúp người sử dụng có thể nhận ra và sửa lỗi kịp thời.

Hàm trả về lỗi

Trong đoạn mã lệnh trên, để trả về thông báo lỗi “#N/A” thì tham số của hàm CVErr phải là hằng số xlErrNA. Có rất nhiều giá trị lỗi khác nhau, mối giá trị lỗi có một hằng số tương ứng. Bảng dưới đây sẽ liệt kê một số thông báo lỗi cũng như các hằng số tương ứng trong VBA.

Một phần của tài liệu Lịch sử máy tính (Trang 181 - 183)