اذهب الي المحتوي
أوفيسنا
بحث مخصص من جوجل فى أوفيسنا
Custom Search

دوال التقريب


إذهب إلى الإجابة الإجابة بواسطة عبد الله-بلال,

الردود الموصى بها

قام بنشر

ألم يطلب السائل أن يجبر النصف إلى واحد صحيح؟ أين تحقق هذا في الاختيار والثاني!!

 

وبدل أن تناقش الأمر بشكل علمي تكلمني عن متلازمة أفضل إجابة!! وعن التوسع!!

 

بدون التوسع لم يفي أحدكم بطلبه والرجل نفسه ما يدري وين الإجابة المناسبة واعتمد على القرعة!.

قام بنشر
10 دقائق مضت, AbuuAhmed said:

ألم يطلب السائل أن يجبر النصف إلى واحد صحيح؟ أين تحقق هذا في الاختيار والثاني!!

 

نعم هي تجبر ، وقد ادرجت دالة المهندس @Eng.Qassim  البارحة في عمل لواحد من الاخوة وكانت النتيجة ممتازة

على كل حال وقصرا لتشعب النقاش كتبت هذا الموضوع للسبب نفسه

قام بنشر
2 ساعات مضت, AbuuAhmed said:

أشكركم أستاد @Foksh على اهتمامكم، حاول تعدل على ملف الإكسل بإزالة دالتك القديم واستبدالها بالحديثة واطلعنا على المقارنة.
أنا عملت دالة vba أخرى باستخدام دوال الإكسل ولو كنت أعرف عنها قبل دوالي الأربع للأكسس لما أجهدت نفسي في تصميمها.

بما ااني حالياً اتابع من الجوال ، لنجرب هذه الفكرة :- 

Public Function RoundCustom(inputValue As Double) As Double
    Dim absValue As Double
    absValue = Abs(inputValue)
    RoundCustom = Sgn(inputValue) * (Int(absValue) + IIf(absValue - Int(absValue) <= 0.5, 0.5, 1))
End Function

والاستدعاء سيكون في الخلية B1 مثلاً :-

=RoundCustom(A1)

 

لست ضليعاً في اكسل لهذا الحد ، ولكن هي فكرة وانتظر تجربتها 😅 من طرفكم أستاذنا الكريم.

قام بنشر

دالة أخيرة في حال أن السائل لا يريد جبر النصف إلى واحد، وهي تعتمد على دالة الإكسل:

Function vbCEILING(ByVal Arg1 As Double, ByVal Arg2 As Double) As Double
    'AbuuAhmed
    Arg2 = Abs(Arg2) * Sgn(Arg1)    'اختياري
    vbCEILING = WorksheetFunction.Ceiling(Arg1, Arg2)
End Function
قام بنشر

وبهذا التعديل :

 

Public Function RoundToNearestHalf(ByVal inputValue As Double) As Double
    Dim absValue As Double
    absValue = Abs(inputValue)
    If absValue - Int(absValue) = 0 Then
        RoundToNearestHalf = inputValue
    ElseIf absValue - Int(absValue) < 0.5 Then
        RoundToNearestHalf = Sgn(inputValue) * (Int(absValue) + 0.5)
    Else
        RoundToNearestHalf = Sgn(inputValue) * (Int(absValue) + 1)
    End If
End Function

 

قام بنشر
10 ساعات مضت, AbuuAhmed said:

أول: أن أكثركم ذهب لمعالجة الكسر إذا كان أصغر من نصف أو (أكبر أو يساوي نصف) ولكن غفل عن الكسر إذا كان صفرا والذي لا يحتاج إلى معالجة.
الآخر: عدم اختبار دوالكم مع الأرقام السالبة، وهذه تحتاج إلى مزيد من العناية والحرص ومعرفة تامة بالتعامل مع دالتي int و fix أو trunc في لغات أخرى.

كل االشكر والتقدير استاذى الجليل و معلمى القدير فعلا لم انتبه او اخذ فى الاعتبار ما تفضلتم به
ولكن على كل حال 

هل هذا الكود استاذى الجليل يفى بالغرض ويأخذ فى الاعتبار كل ما تفضلتم به ام هناك شئ لم انتبه اليه ؟

Public Function CustomRound(ByVal numValue As Double) As String
    On Error GoTo ErrorHandler

    Dim wholePart As Double
    Dim fractionalPart As Double
    
    ' Extract the whole part and the fractional part of the number using Fix for accurate handling of negative numbers
    wholePart = Fix(numValue)
    fractionalPart = numValue - wholePart
    
    ' Custom rounding logic
    If fractionalPart = 0 Then
        CustomRound = wholePart ' No rounding needed for whole numbers
    ElseIf fractionalPart = 0.5 Or fractionalPart = -0.5 Then
        CustomRound = numValue ' Keep the number as it is for ±0.5
    ElseIf numValue > 0 Then
        If fractionalPart < 0.5 Then
            CustomRound = wholePart + 0.5 ' Round to 0.5 for positive numbers
        Else
            CustomRound = wholePart + 1 ' Round up to the next whole number for positive numbers
        End If
    Else
        ' For negative numbers, adjust rounding
        If fractionalPart <= -0.5 Then
            CustomRound = wholePart - 1 ' Round down to the next lower whole number
        Else
            CustomRound = wholePart - 0.5 ' Round to -0.5 for negative numbers
        End If
    End If
    
    ' Format the result to display two decimal places
    CustomRound = Format(CustomRound, "0.00")
    
    Exit Function

ErrorHandler:
    MsgBox "Error in CustomRound function: " & Err.Description, vbCritical, "Error"
    CustomRound = "0.00" ' Return 0.00 in case of an error
End Function

 

قام بنشر (معدل)

آخر تحديث
الأستاذ @Foksh تم التعديل على أحد السطور حتى لا ترجع لي بطلب جديد.
الأكواد في الملف.
أرجو حذف المرفقات السابقة، (ملفات الإكسل فقط مع الإبقاء على المشاركات والصور).
أرجو قفل هذا الموضوع.

image.png.a087e920a5d680ed58fcd6ea415a3137.png

CustomCeiling_03.xlsm

تم تعديل بواسطه AbuuAhmed
  • Thanks 1

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

زائر
اضف رد علي هذا الموضوع....

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

  • تصفح هذا الموضوع مؤخراً   0 اعضاء متواجدين الان

    • لايوجد اعضاء مسجلون يتصفحون هذه الصفحه
×
×
  • اضف...

Important Information