Tìm số lượng chữ số quan trọng (Microsoft Excel)
Brenda quan tâm đến việc biết số chữ số có nghĩa trong một giá trị. Cô ấy tự hỏi liệu có một hàm hoặc công thức Excel nào mà cô ấy có thể sử dụng để trả về số chữ số có nghĩa trong giá trị được hiển thị trong một ô hay không.
Câu hỏi này không đơn giản như nó có vẻ. Đối với một số người, việc tìm số chữ số trong một giá trị, trừ đi bất kỳ dấu thập phân hoặc dấu âm nào.
Nếu đó là tất cả những gì bạn cần, thì một cái gì đó như công thức này sẽ hoạt động tốt:
=IF(A1<0,IF(A1=INT(A1),LEN(A1)-1,LEN(A1)-2),IF(INT(A1)=A1,LEN(A1),LEN(A1)-1))
Tuy nhiên, lý do mà điều này không đơn giản là bởi vì điều gì tạo nên số chữ số có nghĩa trong một giá trị phụ thuộc vào nhiều thứ. Điểm mấu chốt là bạn không phải lúc nào cũng có thể biết được bằng cách nhìn vào một giá trị nó có bao nhiêu chữ số có nghĩa.
Ví dụ: giá trị 100 có thể có 1, 2 hoặc 3 chữ số có nghĩa. Người ta cho rằng giá trị 1.00 có 3 chữ số có nghĩa, nhưng điều đó có thể không đúng nếu giá trị được hiển thị là kết quả của định dạng do Excel áp đặt — ví dụ: giá trị trong ô có thể là 1.0000437, mà Excel định dạng là 1.00. Bạn có thể khám phá thêm về chủ đề chữ số có nghĩa tại đây:
http://excel.tips.net/T001983
Có một số cách được chấp nhận chung để xác định các chữ số có nghĩa trong một số, nhưng bất kỳ nỗ lực nào để hệ thống hóa một bộ quy tắc luôn mở ra tranh luận. Một bộ quy tắc như vậy đã được lưu ý tại Wikipedia, trong phần “Nhận dạng các chữ số quan trọng” của bài viết này:
http://en.wikipedia.org/wiki/Significant_figures
Với ít nhất một bộ quy tắc thô sơ trong tâm trí (chẳng hạn như một bộ quy tắc trong bài viết Wikipedia), bạn có thể phát triển một hàm do người dùng xác định để cung cấp cho bạn số lượng chữ số có nghĩa nhiều nhất cho một giá trị.
Function SigFigs(rng As Range, Optional iType As Integer = 1) 'iType = 1 is Min 'iType = 2 is Max Dim rCell As Range Dim sText As String Dim sText2 As String Dim iMax As Integer Dim iMin As Integer Dim iDec As Integer Dim i As Integer Application.Volatile Set rCell = rng.Cells(1) 'if not a number then error If Not IsNumeric(rCell) Or IsDate(rCell) Then SigFigs = CVErr(xlErrNum) Exit Function End If sText2 = Trim(rCell.Text) sText = "" 'find position of decimal point (it matters) iDec = InStr(sText2, ".") 'strip out any non-numbers (including decimal point) For i = 1 To Len(sText2) If Mid(sText2, i, 1) >= "0" And _ Mid(sText2, i, 1) <= "9" Then _ sText = sText & Mid(sText2, i, 1) Next 'remove any leading zeroes (they don't matter) While Left(sText, 1) = "0" sText = Mid(sText, 2) Wend iMax = Len(sText) 'strip trailing zeroes (they don't matter if no decimal point) sText2 = sText If iDec = 0 Then While Right(sText2, 1) = "0" sText2 = Left(sText2, Len(sText2) - 1) Wend End If iMin = Len(sText2) 'return Min or Max Select Case iType Case 1 SigFigs = iMin Case 2 SigFigs = iMax Case Else SigFigs = CVErr(xlErrNum) End Select End Function
Bạn gọi hàm này bằng cách sử dụng hàm sau trong trang tính của bạn:
=SigFigs(A1, x)
Bạn có thể thay thế x bằng 1 hoặc 2. Nếu bạn chỉ định 1, thì hàm trả về số chữ số có nghĩa tối thiểu. Nếu bạn chỉ định 2, thì hàm trả về số chữ số có nghĩa lớn nhất. Trong hầu hết các trường hợp, hai giá trị trả về có thể sẽ giống nhau, ngoại trừ các giá trị là số nguyên, không có dấu thập phân ở cuối, có số 0 ở cuối. Nói cách khác, nếu bạn sử dụng hàm để đánh giá số 1234000, thì giá trị nhỏ nhất (x là 1)
trả về 4 và tối đa (x là 2) trả về 7.
Hàm xem xét cách số xuất hiện trong trang tính, có nghĩa là nó quan trọng đến cách số đó được định dạng. Nó loại bỏ mọi ký tự định dạng, chẳng hạn như dấu âm, dấu ngoặc đơn và dấu phẩy.
_Lưu ý: _
Nếu bạn muốn biết cách sử dụng các macro được mô tả trên trang này (hoặc trên bất kỳ trang nào khác trên trang ExcelTips), tôi đã chuẩn bị một trang đặc biệt bao gồm thông tin hữu ích.
ExcelTips là nguồn của bạn để đào tạo Microsoft Excel hiệu quả về chi phí.
Mẹo này (10975) áp dụng cho Microsoft Excel 97, 2000, 2002 và 2003.
Bạn có thể tìm thấy phiên bản của mẹo này cho giao diện ribbon của Excel (Excel 2007 trở lên) tại đây: