تقييم الموضوع :
  • 0 أصوات - بمعدل 0
  • 1
  • 2
  • 3
  • 4
  • 5
[سؤال] ماسبب الخطأ في الكود التالي ؟
#1
بسم الله الرحمن الرحيم
السلام عليكم ورحمة الله وبركاته

لدي متغير عام على طول البرنامج اسمه
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

الا ان هناك رسالة خطأ ظهرت، لا ادري ماسببها

ارجو المساعدة في تصويب الامر

والف شكر


الملفات المرفقة صورة/صور
   
الرد
تم الشكر بواسطة:
#2
السلام عليكم...

إذا كنت تقصد التسطير الأخضر تحت عبارة 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.

نرجو الاستفادة و السلام.
بِسْمِ اللهِ الرَّحْمَنِ الرَّحِيمِ ( وَ مَا تُقَدِّمُوا لِأَنفُسِكُم مِّنْ خَيْرٍ تَجِدُوهُ عِندَ اللهِ هُوَ خَيْراً وَ أَعْظَمَ أَجْراً ) صَدَقَ اللهُ الْعَظِيمُ
الرد
تم الشكر بواسطة: kafi2030 , kslawy , العزابي , mohammed moh , sooriaty03
#3
الف الف شكر
اخي / ناجي ابراهيم


على التحليل المنطقي للمشكلة، ووضع الحل المناسب لها

بارك الله فيك

وجزاك الله عني كل خير
الرد
تم الشكر بواسطة:


المواضيع المحتمل أن تكون متشابهة .
الموضوع : الكاتب الردود : المشاهدات : آخر رد
  أيُهما أفضل : ربط قاعدة البيانات باستخدام الأدوات أو ربطها باستخدام الكود ؟ Hazem1 5 50 منذ 54 دقيقة مضت
آخر رد: Hazem1
  [سؤال] مشكلة في الكود في كيفية البحث داخل الداتا جريد من خلال صندوق نصي ؟ dametucorazon 3 120 أمس, 11:27 AM
آخر رد: elgokr
  كيف حل هذا الخطأ الظاهر يا جماعة الخير Hazem1 5 113 16-09-18, 09:56 PM
آخر رد: Hazem1
  [VB.NET] اظهار رسالة في الكود الحفظ Mahamed112 1 54 10-09-18, 12:26 PM
آخر رد: boudyonline
  التعديل على الكود dasktop 3 113 09-09-18, 06:57 AM
آخر رد: elgokr
Wink [VB.NET] عندما ابحث في Crystal Report يظهر لي هذا الخطأ Hosam Ashraf Elwakel 1 75 03-09-18, 06:02 AM
آخر رد: elgokr
  الرجاء تعديل علا المثال التالي لعرض ملف هيكس في ليست بوكس wolf1120 17 428 22-08-18, 10:18 PM
آخر رد: elgokr
  [VB.NET] محتاج تعديل بسيط على الكود dubai.eig 5 150 17-08-18, 03:01 AM
آخر رد: elgokr
  [VB.NET] تعديل علي الكود دموع الوطن 10 285 08-08-18, 09:19 AM
آخر رد: elgokr
  كود زر التالي والسابق في مستعرض الصور معاذ العامري 7 232 25-07-18, 10:07 AM
آخر رد: elgokr

التنقل السريع :


يقوم بقرائة الموضوع: بالاضافة الى ( 1 ) ضيف كريم