تخطي للذهاب إلى المحتوى
أودو القائمة
  • تسجيل الدخول
  • جرب مجاناً
  • التطبيقات
    المالية
    • المحاسبة
    • فوترة
    • النفقات
    • جدول البيانات (BI)
    • المستندات
    • توقيع إلكتروني
    المبيعات
    • إدارة علاقات العملاء
    • المبيعات
    • نقطة البيع للمتاجر
    • نقطة البيع للمطاعم
    • الاشتراكات
    • تأجير
    المواقع الإلكترونية
    • أداة بناء المواقع الإلكترونية
    • متاجر إلكترونية
    • مدونة
    • المنتدى
    • دردشة مباشرة
    • التعليم الإلكتروني
    سلسلة التوريد
    • المستودعات
    • التصنيع
    • إدارة دورة حياة المنتج
    • المشتريات
    • الصيانة
    • الجودة
    الموارد البشرية
    • موظفون
    • التوظيف
    • إجازة عمل
    • التقييمات
    • الإحالات
    • تطبيق الأسطول
    التسويق
    • التسويق الإجتماعي
    • التسويق عبر البريد الإلكتروني
    • التسويق عبر الرسائل النصية
    • فعاليات
    • أتمتة التسويق
    • الاستطلاعات
    الخدمات
    • المشاريع
    • الجداول الزمنية
    • الخدمة الميدانية
    • مكتب المساعدة
    • التخطيط
    • مواعيد
    اﻹنتاجية
    • مناقشة
    • الموافقات
    • إنترنت الأشياء "IoT"
    • بروتوكول ربط المحادثات الصوتية عبر الإنترنت
    • المعرفة
    • WhatsApp
    التطبيقات الخارجية ستوديو أودو منصة أودو السحابية
  • قطاعات الأعمال
    البيع بالتجزئة
    • متجر كتب
    • متجر ملابس
    • متجر أثاث
    • متجر بقالة
    • متجر معدات
    • متجر ألعاب
    الطعام والضيافة
    • بار وحانة
    • المطعم
    • مطعم للوجبات السريعة
    • نزل للضيوف
    • موزّع مشروبات
    • فندق
    العقارات
    • وكالة عقارات
    • شركة هندسة معمارية
    • البناء
    • إدارة العقارات
    • العناية بالحدائق
    • اتحاد مُلاّك العقارات
    استشارة
    • مؤسسة محاسبية
    • شريك أودو
    • وكالة تسويقية
    • منشأة قانونية
    • استقطاب المواهب
    • التدقيق والتوثيق
    التصنيع
    • الأقمشة
    • معدني
    • الأثاث
    • الطعام
    • مصنع خمور
    • هدايا الشركات
    الصحة واللياقة البدنية
    • نادي رياضي
    • متجر نظارات
    • مركز لياقة بدنية
    • الممارسون الصحيون
    • صيدلية
    • صالون تصفيف الشعر
    التجارة
    • عامل صيانة
    • الأجهزة والمعدات التقنية ودعمها
    • أنظمة الطاقة الشمسية
    • صانع أحذية
    • خدمات التنظيف
    • خدمات التكييف (HVAC)
    غير ذلك
    • منظمة غير ربحية
    • وكالة بيئية
    • تأجير لوحات إعلانية
    • تصوير
    • تأجير دراجات
    • بائع وسيط للبرمجيات
    تصفح كافة قطاعات الأعمال
  • مجتمع أودو
    تعلم
    • دروس
    • التوثيق
    • شهادات
    • التدريب
    • مدونة
    • بودكاست
    قم بتعزيز التعليم
    • برنامج تعليم
    • Scale UP! لعبة الأعمال
    • قم بزيارة أودو
    احصل على البرنامج
    • تحميل
    • قارنْ الإصدارات
    • إطلاق
    تعاون
    • جيت هاب "Github"
    • المنتدى
    • فعاليات
    • الترجمات
    • كنْ شريكاً
    • خدمات الشركاء
    • سجل مكتب المحاسبة الخاص بك
    احصل على الخدمات
    • اعثر على شريك
    • اعثر على محاسب
    • قابل أحد مرشدي الأعمال
    • خدمات التنفيذ
    • مراجع العملاء
    • الدعم
    • الترقيات
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    الحصول على عرض توضيحي
  • الأسعار
  • المساعدة

Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:

  • إدارة علاقات العملاء
  • e-Commerce
  • المحاسبة
  • المخزون
  • PoS
  • المشروع
  • MRP
All apps
يجب أن تكون مسجلاً حتى تتفاعل مع المجتمع.
كافة المنشورات الأفراد الشارات
علامات التصنيف (عرض الكل)
odoo accounting v14 pos v15
حول هذا المنتدى
يجب أن تكون مسجلاً حتى تتفاعل مع المجتمع.
كافة المنشورات الأفراد الشارات
علامات التصنيف (عرض الكل)
odoo accounting v14 pos v15
حول هذا المنتدى
المساعدة

Automated Start date calculation based on End date and Allocated hours.

اشتراك

تسلم الإشعارات عندما يكون هناك نشاط في هذا المنشور

لقد تم الإبلاغ عن هذا السؤال
3 الردود
2191 أدوات العرض
الصورة الرمزية
D. PARMAR

Hello all,
I am using Odoo 16. I am working on a custom implementation in Odoo where I need to compute a start date (x_studio_studio_shift_start) for a task based on the end date (x_studio_studio_shift_end) and the allocated hours (allocated_hours). The requirement is that the start date should be calculated by subtracting the allocated hours from the end date.

What I’m Trying to Achieve:

  • Model: planning.slot (this is the model where I'm implementing the logic)
  • Fields:
    • x_studio_studio_shift_start: Start date of the task (computed field)
    • x_studio_studio_shift_end: End date of the task
    • allocated_hours: Number of hours allocated to the task


    • The script below which I have tried but it is giving me errors. "ValueError: forbidden opcode(s) in 'from datetime import timedelta\n\n..."

    • Logic:

    1. Compute Start Date: The start date should be computed by subtracting the allocated hours from the end date. For example, if the end date is August 24, 2024, 08:41:28, and the allocated hours are 8, the start date should be August 23, 2024, 08:41:28.
    2. Planning by Resource: I'm using the Gantt view to manage tasks by resource. The idea is that if I drag and drop a task, the system will first consider the end date, then deduct the allocated hours, and finally set the start date accordingl


  • def _compute_shift_start(self):
    •     for record in self:
    •         if record.x_studio_studio_shift_end and record.allocated_hours:
    •             # Calculate start date by subtracting allocated hours from end date
    •             record.x_studio_studio_shift_start = fields.Datetime.subtract(
    •                 record.x_studio_studio_shift_end, hours=record.allocated_hours
    •             )
    •         else:
    •             record.x_studio_studio_shift_start = record.x_studio_studio_shift_end

  • 0
    الصورة الرمزية
    إهمال
    الصورة الرمزية
    S.A. Methsiri Madusanka Sooriyaarachchi
    أفضل إجابة

    To compute the start date based on the end date and allocated hours in Odoo, you can use Python's datetime module to handle date and time calculations. In Odoo 16, you would generally use datetime.timedelta for this kind of calculation. The error you encountered suggests there's an issue with the way you're trying to subtract time from a date.

    Here's how you can correctly implement this in your model:

    1. Ensure datetime Module Import:
      • Import datetime and timedelta at the beginning of your Python file.
    2. Correct Computation Method:
      • Use timedelta to subtract hours from the end date. The fields.Datetime class in Odoo doesn't directly support operations like subtraction, so you need to convert the datetime field to a Python datetime object, perform the calculation, and then set the result back to the Odoo field.

    Here’s how you can update your _compute_shift_start method:

    pythonCopy codefrom datetime import datetime, timedelta
    from odoo import models, fields
    
    class PlanningSlot(models.Model):
        _name = 'planning.slot'
        _description = 'Planning Slot'
    
        x_studio_studio_shift_start = fields.Datetime(compute='_compute_shift_start', store=True)
        x_studio_studio_shift_end = fields.Datetime(string='End Date')
        allocated_hours = fields.Float(string='Allocated Hours')
    
        def _compute_shift_start(self):
            for record in self:
                if record.x_studio_studio_shift_end and record.allocated_hours:
                    end_date = fields.Datetime.from_string(record.x_studio_studio_shift_end)
                    allocated_time = timedelta(hours=record.allocated_hours)
                    start_date = end_date - allocated_time
                    record.x_studio_studio_shift_start = fields.Datetime.to_string(start_date)
                else:
                    record.x_studio_studio_shift_start = record.x_studio_studio_shift_end
    

    Explanation:

    1. Imports:
      • timedelta is used to create a time difference of the allocated hours.
    2. Conversion to datetime:
      • fields.Datetime.from_string(record.x_studio_studio_shift_end) converts the Odoo datetime field to a Python datetime object.
      • fields.Datetime.to_string(start_date) converts the Python datetime object back to an Odoo-compatible datetime string.
    3. Subtracting Time:
      • end_date - allocated_time performs the date-time subtraction to compute the start date.

    Additional Notes:

    • Ensure that store=True is used in the field definition if you want to persist computed values in the database.
    • If the allocated_hours can be a fraction (e.g., 8.5 hours), ensure that your model's field type is set to Float for allocated_hours.

    This approach should work for your requirement to compute the start date by subtracting allocated hours from the end date. Let me know if you encounter any further issues!

    1
    الصورة الرمزية
    إهمال
    الصورة الرمزية
    D. PARMAR
    الكاتب أفضل إجابة

    This does not work.

    0
    الصورة الرمزية
    إهمال
    الصورة الرمزية
    Yahoo Baba Innovations Pvt.Ltd
    أفضل إجابة

    Hi,

    Have a look at this:

    @api.depends( 'x_studio_studio_shift_end' , 'allocated_hours' ) 

    def _compute_shift_start ( self ): 

    for record in self: 

    ​if record.x_studio_studio_shift_end and record.allocated_hours: 

          ​ ​# Calculate start date by subtracting allocated hours from end date record.

    ​​x_studio_studio_shift_start = record. x_studio_studio_shift_end - timedelta(hours=record.allocated_hours)  ​

    ​else : 

    ​ ​record.x_studio_studio_shift_start = record.x_studio_studio_shift_end ​


    Thanks & Regards,

    0
    الصورة الرمزية
    إهمال
    هل أعجبك النقاش؟ لا تكن مستمعاً فقط. شاركنا!

    أنشئ حساباً اليوم لتستمتع بالخصائص الحصرية، وتفاعل مع مجتمعنا الرائع!

    تسجيل
    المجتمع
    • دروس
    • التوثيق
    • المنتدى
    مصدر مفتوح
    • تحميل
    • جيت هاب "Github"
    • المشغل الآلي رنبوت
    • الترجمات
    خدماتنا
    • استضافة أودو إس إتش
    • الدعم
    • الترقية
    • التطويرات المخصصة
    • التعليم
    • اعثر على محاسب
    • اعثر على شريك
    • كنْ شريكاً
    معلومات عنا
    • شركتنا
    • أصول العلامة التجارية
    • اتصلْ بنا
    • الوظائف
    • فعاليات
    • بودكاست
    • مدونة
    • عملاء
    • قانوني • الخصوصية
    • الحماية
    الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk slovenščina Español (América Latina) Español ภาษาไทย Türkçe українська Tiếng Việt

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

    ما يجعل من أودو مميزاً هو هدفه بأن يكون سهل الاستخدام للغاية ومتكاملاً تمامًا في الوقت ذاته.

    Website made with

    Odoo Experience on YouTube

    1. Use the live chat to ask your questions.
    2. The operator answers within a few minutes.

    Live support on Youtube
    Watch now