بسم الله الرحمن الرحيم
السلام عليكم ورحمة الله وبركاته
لدي متغير عام على طول البرنامج اسمه
My_No_Digits
يحمل هذا المتغير احد القيم الثلاث
اما 0 بمعنى انه لا توجد ارقام عشرية بعد الفاصلة اي الرقم مظهره 125,315
او 2 بمعنى انه يوجد رقمان عشريان بعد الفاصلة اي الرقم مظهره 345,000.45
او 3 بمعنى انه يوجد ثلاث ارقام عشرية بعد الفاصلة اي الرقم مظهرة 185,000.425
انا اريد ان انسق الرقم الموجود بالتكست بوكس، وفق قيمة المتغير My_No_Digits
قمت بانشاء وحدة نمطية Module
وانشأت فيها function
ارسل من خلاله قيمة التكست بوكس، ويعمل الفانكش على فحص الحالة المناسبة ومن ثم يرجع القيمة المرسلة له منسقة حسب حالة المتغير my_No_Digits
كود :
Module My_function
Public Function format_my_Number(ByVal st As String) As String
Dim val As Double
If Trim(st) = "" Then st = 0
val = st
Select Case My_No_Digits
Case 0
format_my_Number = val.ToString("##,###,###")
Case 2
format_my_Number = val.ToString("##,###,###.##")
Case 3
format_my_Number = val.ToString("##,###,###.###")
End Select
End Function
End Module
الا ان هناك رسالة خطأ ظهرت، لا ادري ماسببها
ارجو المساعدة في تصويب الامر
والف شكر
السلام عليكم...
إذا كنت تقصد التسطير الأخضر تحت عبارة End Function فالسبب هو أن الـ Compiler ينبهك إلى احتمال أن الدالة قد تعيد NULL ما قد يتسبب في حدوث خطأ أثناء التنفيذ. لكن الخطأ قد لا يحدث إذا تم استدعاء الدالة بالقيم المناسبة.
الدالة قد تعيد NULL إذا كانت قيمة المتغير My_No_Digits لا تساوي إحدى القيم الثلاث 0 أو 2 أو 3.
الحل: إما أن تحدد في البداية قيمة افتراضية تعيدها الدالة في حالة لم تكن قيمة My_No_Digits هي 0 أو 2 أو 3، أو أن تضيف إلى كتلة Select Case عبارة Case Else لإرجاع القيمة الافتراضية:
* هكذا:
كود :
Module My_function
Public Function format_my_Number(ByVal st As String) As String
Dim val As Double
If Trim(st) = "" Then st = 0
val = st
format_my_Number = val.ToString("##,###,###") ' تحديد قيمة افتراضية
Select Case My_No_Digits
Case 2
format_my_Number = val.ToString("##,###,###.##")
Case 3
format_my_Number = val.ToString("##,###,###.###")
End Select
End Function
End Module
* أو هكذا:
كود :
Module My_function
Public Function format_my_Number(ByVal st As String) As String
Dim val As Double
If Trim(st) = "" Then st = 0
val = st
Select Case My_No_Digits
Case 2
format_my_Number = val.ToString("##,###,###.##")
Case 3
format_my_Number = val.ToString("##,###,###.###")
Case Else
format_my_Number = val.ToString("##,###,###") ' تحديد قيمة افتراضية
End Select
End Function
End Module
*** لاحظ أن القيمة الافتراضية - سواءً قبل عبارة Select Case أو داخلها باستعمال Case Else - سيتم إرجاعها في حالة أن قيمة My_No_Digits ليست 2 و ليست 3.
نرجو الاستفادة و السلام.
الف الف شكر
اخي / ناجي ابراهيم
على التحليل المنطقي للمشكلة، ووضع الحل المناسب لها
بارك الله فيك
وجزاك الله عني كل خير