Overslaan naar inhoud
Odoo Menu
  • Aanmelden
  • Probeer het gratis
  • Apps
    Financiën
    • Boekhouding
    • Facturatie
    • Onkosten
    • Spreadsheet (BI)
    • Documenten
    • Ondertekenen
    Verkoop
    • CRM
    • Verkoop
    • Kassasysteem winkel
    • Kassasysteem Restaurant
    • Abonnementen
    • Verhuur
    Websites
    • Websitebouwer
    • E-commerce
    • Blog
    • Forum
    • Live Chat
    • eLearning
    Bevoorradingsketen
    • Voorraad
    • Productie
    • PLM
    • Inkoop
    • Onderhoud
    • Kwaliteit
    Personeelsbeheer
    • Werknemers
    • Werving & Selectie
    • Verlof
    • Evaluaties
    • Aanbevelingen
    • Wagenpark
    Marketing
    • Sociale media-marketing
    • E-mailmarketing
    • Sms-marketing
    • Evenementen
    • Marketingautomatisering
    • Enquêtes
    Diensten
    • Project
    • Urenstaten
    • Buitendienst
    • Helpdesk
    • Planning
    • Afspraken
    Productiviteit
    • Chat
    • Goedkeuringen
    • IoT
    • VoIP
    • Kennis
    • WhatsApp
    Apps van derden Odoo Studio Odoo Cloud Platform
  • Bedrijfstakken
    Detailhandel
    • Boekhandel
    • kledingwinkel
    • Meubelzaak
    • Supermarkt
    • Bouwmarkt
    • Speelgoedwinkel
    Food & Hospitality
    • Bar en Pub
    • Restaurant
    • Fastfood
    • Gastenverblijf
    • Drankenhandelaar
    • Hotel
    Vastgoed
    • Makelaarskantoor
    • Architectenbureau
    • Bouw
    • Vastgoedbeheer
    • Tuinieren
    • Vereniging van eigenaren
    Consulting
    • Accountantskantoor
    • Odoo Partner
    • Marketingbureau
    • Advocatenkantoor
    • Talentenwerving
    • Audit & Certificering
    Productie
    • Textiel
    • Metaal
    • Meubels
    • Eten
    • Brewery
    • Relatiegeschenken
    Gezondheid & Fitness
    • Sportclub
    • Opticien
    • Fitnesscentrum
    • Wellness-medewerkers
    • Apotheek
    • Kapper
    Trades
    • Klusjesman
    • IT-hardware & support
    • Zonne-energiesystemen
    • Schoenmaker
    • Schoonmaakdiensten
    • HVAC-diensten
    Andere
    • Non-profitorganisatie
    • Milieuagentschap
    • Verhuur van Billboards
    • Fotograaf
    • Fietsleasing
    • Softwareverkoper
    Browse all Industries
  • Community
    Leren
    • Tutorials
    • Documentatie
    • Certificeringen
    • Training
    • Blog
    • Podcast
    Versterk het onderwijs
    • Onderwijs- programma
    • Scale Up! Business Game
    • Bezoek Odoo
    Download de Software
    • Downloaden
    • Vergelijk edities
    • Releases
    Werk samen
    • Github
    • Forum
    • Evenementen
    • Vertalingen
    • Word een Partner
    • Services for Partners
    • Registreer je accountantskantoor
    Diensten
    • Vind een partner
    • Vind een boekhouder
    • Een adviseur ontmoeten
    • Implementatiediensten
    • Klantreferenties
    • Ondersteuning
    • Upgrades
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Vraag een demo aan
  • Prijzen
  • Help

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

  • CRM
  • e-Commerce
  • Boekhouding
  • Voorraad
  • PoS
  • Project
  • MRP
All apps
Je moet geregistreerd zijn om te kunnen communiceren met de community.
Alle posts Personen Badges
Labels (Bekijk alle)
odoo accounting v14 pos v15
Over dit forum
Je moet geregistreerd zijn om te kunnen communiceren met de community.
Alle posts Personen Badges
Labels (Bekijk alle)
odoo accounting v14 pos v15
Over dit forum
Help

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

Inschrijven

Ontvang een bericht wanneer er activiteit is op deze post

Deze vraag is gerapporteerd
3 Antwoorden
2180 Weergaven
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
    Annuleer
    Avatar
    S.A. Methsiri Madusanka Sooriyaarachchi
    Beste antwoord

    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
    Annuleer
    Avatar
    D. PARMAR
    Auteur Beste antwoord

    This does not work.

    0
    Avatar
    Annuleer
    Avatar
    Yahoo Baba Innovations Pvt.Ltd
    Beste antwoord

    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
    Annuleer
    Geniet je van het gesprek? Blijf niet alleen lezen, doe ook mee!

    Maak vandaag nog een account aan om te profiteren van exclusieve functies en deel uit te maken van onze geweldige community!

    Aanmelden
    Community
    • Tutorials
    • Documentatie
    • Forum
    Open Source
    • Downloaden
    • Github
    • Runbot
    • Vertalingen
    Diensten
    • Odoo.sh Hosting
    • Ondersteuning
    • Upgrade
    • Gepersonaliseerde ontwikkelingen
    • Onderwijs
    • Vind een boekhouder
    • Vind een partner
    • Word een Partner
    Over ons
    • Ons bedrijf
    • Merkelementen
    • Neem contact met ons op
    • Vacatures
    • Evenementen
    • Podcast
    • Blog
    • Klanten
    • Juridisch • Privacy
    • Beveiliging
    الْعَرَبيّة 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 is een suite van open source zakelijke apps die aan al je bedrijfsbehoeften voldoet: CRM, E-commerce, boekhouding, inventaris, kassasysteem, projectbeheer, enz.

    Odoo's unieke waardepropositie is om tegelijkertijd zeer gebruiksvriendelijk en volledig geïntegreerd te zijn.

    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