Noname > 23-05-19, 11:53 AM
Function Eval(Ref As String)
Application.Volatile
Eval = Evaluate(Ref)
End Function
Xuân Thanh > 05-06-19, 08:16 AM
Option Explicit
Const Dau = "{}[]()+-*/^"
Function GiaTri(strChuoi As String)
Application.Volatile
Dim i As Long, j As Long, KQ As String
KQ = ""
strChuoi = Trim(strChuoi)
For i = 1 To Len(strChuoi)
If IsNumeric(Mid(strChuoi, i, 1)) = True Then
KQ = KQ & Mid(strChuoi, i, 1)
End If
For j = 1 To Len(Dau)
If Mid(strChuoi, i, 1) = Mid(Dau, j, 1) Then
KQ = KQ & Mid(Dau, j, 1)
End If
Next
Next
GiaTri = Evaluate(KQ)
End Function
Noname > 29-02-20, 04:54 PM
FORMULATEXT(ô có chứa công thức)
Function FORMULATEXT(r As Range)
FORMULATEXT = r.Formula
End Function
Noname > 19-03-20, 03:28 PM
Function Sum2T(r As Range)
For Each cl In r
If cl <> "" Then
Sum2T = Sum2T & cl.value & "+"
End If
Next
Sum2T = Left(Sum2T, Len(Sum2T) - 1)
End Function
gobi > 19-01-21, 04:43 PM
(05-06-19, 08:16 AM)Xuân Thanh Đã viết: Mở rộng hàm của NoName để áp dụng cho nhiều trường hợp
Mã:Option Explicit
Const Dau = "{}[]()+-*/^"
Function GiaTri(strChuoi As String)
Application.Volatile
Dim i As Long, j As Long, KQ As String
KQ = ""
strChuoi = Trim(strChuoi)
For i = 1 To Len(strChuoi)
If IsNumeric(Mid(strChuoi, i, 1)) = True Then
KQ = KQ & Mid(strChuoi, i, 1)
End If
For j = 1 To Len(Dau)
If Mid(strChuoi, i, 1) = Mid(Dau, j, 1) Then
KQ = KQ & Mid(Dau, j, 1)
End If
Next
Next
GiaTri = Evaluate(KQ)
End Function
Ví dụ
strChuoi = 5người * (5em -2em) ====> GiaTri = 15
strChuoi = 5^2+3^2 ==== GiaTri = 34
Noname > 25-01-21, 11:24 AM
(19-01-21, 04:43 PM)gobi Đã viết:(05-06-19, 08:16 AM)Xuân Thanh Đã viết: Mở rộng hàm của NoName để áp dụng cho nhiều trường hợp
Mã:Option Explicit
Const Dau = "{}[]()+-*/^"
Function GiaTri(strChuoi As String)
Application.Volatile
Dim i As Long, j As Long, KQ As String
KQ = ""
strChuoi = Trim(strChuoi)
For i = 1 To Len(strChuoi)
If IsNumeric(Mid(strChuoi, i, 1)) = True Then
KQ = KQ & Mid(strChuoi, i, 1)
End If
For j = 1 To Len(Dau)
If Mid(strChuoi, i, 1) = Mid(Dau, j, 1) Then
KQ = KQ & Mid(Dau, j, 1)
End If
Next
Next
GiaTri = Evaluate(KQ)
End Function
Ví dụ
strChuoi = 5người * (5em -2em) ====> GiaTri = 15
strChuoi = 5^2+3^2 ==== GiaTri = 34
em đã áp dụng đoạn mã này. nhưng khi chung số lẻ thì nó bỏ luôn dấu phẩy, làm sai kết quả. em không phải dân lập trình, nhờ a chỉnh lại mã để em có thể dùng với số lẻ. vd: 0,14*0,5*8 . cảm ơn anh nhiều ạ!