Skip ke Konten
Odoo Menu
  • Login
  • Uji coba gratis
  • Aplikasi
    Keuangan
    • Akuntansi
    • Faktur
    • Pengeluaran
    • Spreadsheet (BI)
    • Dokumen
    • Tanda Tangan
    Sales
    • CRM
    • Sales
    • POS Toko
    • POS Restoran
    • Langganan
    • Rental
    Website
    • Website Builder
    • eCommerce
    • Blog
    • Forum
    • Live Chat
    • eLearning
    Rantai Pasokan
    • Inventaris
    • Manufaktur
    • PLM
    • Purchase
    • Maintenance
    • Kualitas
    Sumber Daya Manusia
    • Karyawan
    • Rekrutmen
    • Cuti
    • Appraisal
    • Referensi
    • Armada
    Marketing
    • Social Marketing
    • Email Marketing
    • SMS Marketing
    • Acara
    • Otomatisasi Marketing
    • Survei
    Layanan
    • Project
    • Timesheet
    • Layanan Lapangan
    • Meja Bantuan
    • Planning
    • Appointment
    Produktivitas
    • Discuss
    • Approval
    • IoT
    • VoIP
    • Pengetahuan
    • WhatsApp
    Aplikasi pihak ketiga Odoo Studio Platform Odoo Cloud
  • Industri-Industri
    Retail
    • Toko Buku
    • Toko Baju
    • Toko Furnitur
    • Toko Kelontong
    • Toko Hardware
    • Toko Mainan
    Makanan & Hospitality
    • Bar dan Pub
    • Restoran
    • Fast Food
    • Rumah Tamu
    • Distributor Minuman
    • Hotel
    Real Estate
    • Agensi Real Estate
    • Firma Arsitektur
    • Konstruksi
    • Estate Management
    • Perkebunan
    • Asosiasi Pemilik Properti
    Konsultansi
    • Firma Akuntansi
    • Mitra Odoo
    • Agensi Marketing
    • Firma huku
    • Talent Acquisition
    • Audit & Sertifikasi
    Manufaktur
    • Tekstil
    • Logam
    • Perabotan
    • Makanan
    • Brewery
    • Corporate Gift
    Kesehatan & Fitness
    • Sports Club
    • Toko Kacamata
    • Fitness Center
    • Wellness Practitioners
    • Farmasi
    • Salon Rambut
    Perdagangan
    • Handyman
    • IT Hardware & Support
    • Sistem-Sistem Energi Surya
    • Pembuat Sepatu
    • Cleaning Service
    • Layanan HVAC
    Lainnya
    • Organisasi Nirlaba
    • Agen Lingkungan
    • Rental Billboard
    • Fotografi
    • Penyewaan Sepeda
    • Reseller Software
    Browse semua Industri
  • Komunitas
    Belajar
    • Tutorial-tutorial
    • Dokumentasi
    • Sertifikasi
    • Pelatihan
    • Blog
    • Podcast
    Empower Education
    • Program Edukasi
    • Game Bisnis 'Scale Up!'
    • Kunjungi Odoo
    Dapatkan Softwarenya
    • Download
    • Bandingkan Edisi
    • Daftar Rilis
    Kolaborasi
    • Github
    • Forum
    • Acara
    • Terjemahan
    • Menjadi Partner
    • Layanan untuk Partner
    • Daftarkan perusahaan Akuntansi Anda.
    Dapatkan Layanan
    • Temukan Mitra
    • Temukan Akuntan
    • Temui penasihat
    • Layanan Implementasi
    • Referensi Pelanggan
    • Bantuan
    • Upgrades
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Dapatkan demo
  • Harga
  • Bantuan

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

  • CRM
  • e-Commerce
  • Akuntansi
  • Inventaris
  • PoS
  • Project
  • MRP
All apps
Anda harus terdaftar untuk dapat berinteraksi di komunitas.
Semua Post Orang Lencana-Lencana
Label (Lihat semua)
odoo accounting v14 pos v15
Mengenai forum ini
Anda harus terdaftar untuk dapat berinteraksi di komunitas.
Semua Post Orang Lencana-Lencana
Label (Lihat semua)
odoo accounting v14 pos v15
Mengenai forum ini
Help

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

Langganan

Dapatkan notifikasi saat terdapat aktivitas pada post ini

Pertanyaan ini telah diberikan tanda
3 Replies
2174 Tampilan
Avatar
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
    Avatar
    Buang
    Avatar
    S.A. Methsiri Madusanka Sooriyaarachchi
    Jawaban Terbai

    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
    Avatar
    Buang
    Avatar
    D. PARMAR
    Penulis Jawaban Terbai

    This does not work.

    0
    Avatar
    Buang
    Avatar
    Yahoo Baba Innovations Pvt.Ltd
    Jawaban Terbai

    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
    Avatar
    Buang
    Menikmati diskusi? Jangan hanya membaca, ikuti!

    Buat akun sekarang untuk menikmati fitur eksklufi dan agar terlibat dengan komunitas kami!

    Daftar
    Komunitas
    • Tutorial-tutorial
    • Dokumentasi
    • Forum
    Open Source
    • Download
    • Github
    • Runbot
    • Terjemahan
    Layanan
    • Odoo.sh Hosting
    • Bantuan
    • Peningkatan
    • Custom Development
    • Pendidikan
    • Temukan Akuntan
    • Temukan Mitra
    • Menjadi Partner
    Tentang Kami
    • Perusahaan kami
    • Aset Merek
    • Hubungi kami
    • Tugas
    • Acara
    • Podcast
    • Blog
    • Pelanggan
    • Hukum • Privasi
    • Keamanan
    الْعَرَبيّة 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

    Odoo adalah rangkaian aplikasi bisnis open source yang mencakup semua kebutuhan perusahaan Anda: CRM, eCommerce, akuntansi, inventaris, point of sale, manajemen project, dan seterusnya.

    Mudah digunakan dan terintegrasi penuh pada saat yang sama adalah value proposition unik Odoo.

    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