Skip to Content
Odoo मेन्यू
  • Sign in
  • मुफ़्त में आज़माएं
  • ऐप्लिकेशन
    फ़ाइनेंस
    • अकाउंटिंग
    • इनवॉइसिंग
    • एक्सपेंस
    • स्प्रेडशीट (बीआई)
    • डॉक्यूमेंट्स
    • साइन
    सेल्स
    • सीआरएम
    • सेल्स
    • पीओएस शॉप
    • पीओएस रेस्टोरेंट
    • सब्सक्रिप्शन
    • रेंटल
    वेबसाइट
    • वेबसाइट बिल्डर
    • ई-कॉमर्स
    • ब्लॉग
    • फ़ोरम
    • लाइव चैट
    • ई-लर्निंग
    सप्लाई चेन
    • इन्वेंट्री
    • मैन्युफ़ैक्चरिंग
    • पीएलएम
    • परचेज़
    • मेंटेनेंस
    • क्वालिटी
    मानव संसाधन
    • कर्मचारी
    • रिक्रूटमेंट
    • टाइम ऑफ़
    • अप्रेज़ल
    • रेफ़रल
    • फ़्लीट
    मार्केटिंग
    • सोशल मार्केटिंग
    • ईमेल मार्केटिंग
    • एसएमएस मार्केटिंग
    • इवेंट
    • मार्केटिंग ऑटोमेशन
    • सर्वे
    सेवाएं
    • प्रोजेक्ट
    • टाइमशीट
    • फ़ील्ड सर्विस
    • हेल्पडेस्क
    • प्लानिंग
    • अपॉइंटमेंट
    प्रॉडक्टिविटी
    • डिस्कस
    • अप्रूवल
    • आईओटी
    • वीओआईपी
    • नॉलेज
    • WhatsApp
    तीसरे पक्ष के ऐप्लिकेशन Odoo स्टूडियो Odoo क्लाउड प्लेटफ़ॉर्म
  • इंडस्ट्री
    रीटेल
    • बुक स्टोर
    • क्लोदिंग स्टोर
    • फ़र्नीचर स्टोर
    • ग्रॉसरी स्टोर
    • हार्डवेयर स्टोर
    • टॉय स्टोर
    Food & Hospitality
    • बार और पब
    • रेस्टोरेंट
    • फ़ास्ट फ़ूड
    • Guest House
    • बेवरिज डिस्ट्रीब्यूटर
    • होटल
    रियल एस्टेट
    • Real Estate Agency
    • आर्किटेक्चर फ़र्म
    • कंसट्रक्शन
    • एस्टेट मैनेजमेंट
    • गार्ड्निंग
    • प्रॉपर्टी ओनर असोसिएशन
    कंसल्टिंग
    • अकाउंटिंग फ़र्म
    • Odoo पार्टनर
    • मार्केटिंग एजेंसी
    • लॉ फ़र्म
    • टैलेंट ऐक्विज़िशन
    • ऑडिट & सर्टिफ़िकेशन
    मैन्युफ़ैक्चरिंग
    • टेक्सटाइल
    • Metal
    • फ़र्नीचर
    • फ़ूड
    • Brewery
    • कॉर्पोरेट गिफ़्ट
    हेल्थ & फिटनेस
    • स्पोर्ट्स क्लब
    • आईवियर स्टोर
    • फिटनेस सेंटर
    • वेलनेस प्रैक्टिशनर
    • फॉर्मेसी
    • हेयर सैलून
    Trades
    • Handyman
    • आईटी हॉर्डवेयर और सपोर्ट
    • Solar Energy Systems
    • Shoe Maker
    • Cleaning Services
    • HVAC Services
    अन्य
    • Nonprofit Organization
    • एन्वायरमेंटल एजेंसी
    • बिलबोर्ड रेंटल
    • फ़ोटोग्राफी
    • बाइक लीजिंग
    • सॉफ़्टवेयर रीसेलर
    Browse all Industries
  • कम्यूनिटी
    सीखें
    • ट्यूटोरियल्स
    • दस्तावेज़
    • सर्टिफ़िकेशन
    • ट्रेनिंग
    • ब्लॉग
    • पॉडकास्ट
    शिक्षा को बढ़ावा दें
    • एजुकेशन प्रोग्राम
    • स्केल अप! बिजनेस गेम
    • Odoo के ऑफ़िस में आएं
    सॉफ़्टवेयर पाएं
    • डाउनलोड
    • वर्शन की तुलना करें
    • रिलीज़
    साथ मिलकर काम करें
    • Github
    • फ़ोरम
    • इवेंट
    • अनुवाद
    • पार्टनर बनें
    • Services for Partners
    • अपना अकाउंटिंग फ़र्म रजिस्टर करें
    सेवाएं पाएं
    • पार्टनर ढूंढें
    • अकाउंटेंट खोजें
    • सलाहकार की मदद लें
    • इम्प्लिमेंटेशन सेवाएं
    • कस्टमर रेफ़रेंस
    • सहायता
    • अपग्रेड
    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
You need to be registered to interact with the community.
All Posts People Badges
टैग (View all)
odoo accounting v14 pos v15
About this forum
You need to be registered to interact with the community.
All Posts People Badges
टैग (View all)
odoo accounting v14 pos v15
About this forum
Help

Programatically reserve items

Subscribe

Get notified when there's activity on this post

This question has been flagged
mrp12.04Enterprise
2819 Views
Avatar
Emil Dela Cruz

As a requirement, once Work Orders are created in an MO, all pickings related to that MO must be automatically booked and validated.

Below is the code I created for the task. It seems to work fine as all pickings are validated except when there aren't enough raw material quantity on hand. However and especially for the wood items with lot numbers, it seems the bookings are not properly being deducted from the inventory. Can someone review my code and check if the manner of how I reserve the items are valid or is there a better approach? Thanks in advance!

============================

# find out if this order has components
mo_records = env['mrp.production'].search(["&","&",["origin","=",record.name],["state","=","confirmed"],["routing_id.x_studio_bom_type","=","Component"]])

if mo_records:
# components were found
raise Warning('Cảnh báo: Bạn phải xác nhận và sản xuất tất cả các đơn đặt hàng linh kiện trước khi xác nhận đơn đặt hàng sản xuất chính này! (Warning: You must confirm and produce all component orders before confirming this main production order!)')

else:
# no components were found, so this is main order
records.button_plan()

#This sequence of codes will auto-reserve and confirm related picking orders of the MO after creating the work orders
pickings = env['stock.picking'].search(['&','&',('origin','=',record.name),('picking_type_id','=',21),('state','in',['confirmed','assigned'])])

if pickings:
for picking in pickings:
picking.action_confirm()
picking.action_assign()

# process and validate the material picking transaction
move_items = env['stock.move'].search([('picking_id','=',picking\.id\)\]\)
\ \ \ \
\ \ \ \ for\ move\ in\ move_items:
\ \ \ \ \ \ has_lines\ =\ env\['stock\.move\.line'\]\.search\(\[\('move_id','=',move\.id\)\]\)

\ \ \ \ \ \ if\ has_lines:
\ \ \ \ \ \ \ \ for\ line\ in\ has_lines:
\ \ \ \ \ \ \ \ \ \ line\['qty_done'\]\ =\ line\.product_uom_qty

\ \ \ \ \ \ \ \ \ \ \#\ if\ a\ picking\ material\ is\ wood\ and\ has\ tracking\ for\ lot\ numbers,\ record\ the\ consumption\ into\ x_mrp_picking_lots\ for\ later\ consolidated\ consumption\ report
\ \ \ \ \ \ \ \ \ \ if\ line\.lot_id:
\ \ \ \ \ \ \ \ \ \ \ \ lot_move_lines\ =\ env\['stock\.move\.line'\]\.search\(\['\&','\&',\('lot_id','=',line\.lot_id\.id\),\('reference','like','WH/IN%'\),\('location_id','=',8\)\],\ limit=1\)
\ \ \ \ \ \ \ \ \ \ \ \ orders\ =\ env\['purchase\.order'\]\.search\(\[\('name','=',lot_move_lines\[0\]\.x_studio_po_reference\)\],\ limit=1\)
\ \ \ \ \ \ \ \ \ \ \ \ if\ orders:
\ \ \ \ \ \ \ \ \ \ \ \ \ \ order_id\ =\ orders\[0\]\.id
\ \ \ \ \ \ \ \ \ \ \ \ else:
\ \ \ \ \ \ \ \ \ \ \ \ \ \ order_id\ =\ False
\ \ \ \ \ \ \ \ \ \ \ \
\ \ \ \ \ \ \ \ \ \ \ \ is_fsc\ =\ False
\ \ \ \ \ \ \ \ \ \ \ \
\ \ \ \ \ \ \ \ \ \ \ \ if\ record\.product_id\.product_tmpl_id\.categ_id\.id\ ==\ 34\ and\ record\.product_id\.product_tmpl_id\.x_fsc_category\ ==\ True:\ \#\ is\ FG\ and\ FSC\ Category\ is\ set
\ \ \ \ \ \ \ \ \ \ \ \ \ \ is_fsc\ =\ True
\ \ \ \ \ \ \ \ \ \ \ \ else:
\ \ \ \ \ \ \ \ \ \ \ \ \ \ is_fsc\ =\ False
\ \ \ \ \ \ \ \ \ \ \ \ \ \
\ \ \ \ \ \ \ \ \ \ \ \ mrps\ =\ env\['mrp\.production'\]\.search\(\[\('name','=',record\.origin\)\]\)
\ \ \ \ \ \ \ \ \ \ \ \ if\ mrps:
\ \ \ \ \ \ \ \ \ \ \ \ \ \ source_mrp\ =\ mrps\[0\]\.id
\ \ \ \ \ \ \ \ \ \ \ \ \ \
\ \ \ \ \ \ \ \ \ \ \ \ env\['x_mrp_picking_lots'\]\.create\(\{
\ \ \ \ \ \ \ \ \ \ \ \ \ \ 'x_name':record\.name,
\ \ \ \ \ \ \ \ \ \ \ \ \ \ 'x_name2':\ record\.id,
\ \ \ \ \ \ \ \ \ \ \ \ \ \ 'x_source':\ record\.origin,
\ \ \ \ \ \ \ \ \ \ \ \ \ \ 'x_source2':\ source_mrp,
\ \ \ \ \ \ \ \ \ \ \ \ \ \ 'x_product_id':line\.product_id\.id,
\ \ \ \ \ \ \ \ \ \ \ \ \ \ 'x_lot_id':line\.lot_id\.id,
\ \ \ \ \ \ \ \ \ \ \ \ \ \ 'x_purchase_order':\ order_id,
\ \ \ \ \ \ \ \ \ \ \ \ \ \ 'x_qty_used':line\.product_uom_qty,
\ \ \ \ \ \ \ \ \ \ \ \ \ \ 'x_uom':line\.product_uom_id\.id,
\ \ \ \ \ \ \ \ \ \ \ \ \ \ 'x_fg_fsc':\ is_fsc,
\ \ \ \ \ \ \ \ \ \ \ \ \ \ 'x_state':'assigned'
\ \ \ \ \ \ \ \ \ \ \ \ \}\)
\ \ \ \ \ \ \ \ \ \ \ \
\ \ \ \ \ \ \ \ \ \ if\ move\.product_id\.type\ !=\ 'consu':
\ \ \ \ \ \ \ \ \ \ \ \ \#\ record\ the\ reserved\ quantity\ into\ Pre\-Production
\ \ \ \ \ \ \ \ \ \ \ \ quants\ =\ env\['stock\.quant'\]\.search\(\[\('product_id','=',line\.product_id\.id\),\('location_id','=',\ 34\),\('lot_id','=',\ False\)\],limit=1\)
\ \ \ \ \ \ \ \ \ \ \ \
\ \ \ \ \ \ \ \ \ \ \ \ if\ quants:
\ \ \ \ \ \ \ \ \ \ \ \ \ \ for\ quant\ in\ quants:
\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ quants\['quantity'\]\ =\ quant\.quantity\ \+\ line\.product_uom_qty
\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ quants\['reserved_quantity'\]\ =\ quant\.reserved_quantity\ \+\ line\.product_uom_qty
\ \ \ \ \ \ \ \ \ \ \ \ else:
\ \ \ \ \ \ \ \ \ \ \ \ \ \ env\['stock\.quant'\]\.sudo\(\)\.create\(\{'product_id':\ line\.product_id\.id,\ 'location_id':\ 34,\ 'quantity':\ line\.product_uom_qty,\ 'reserved_quantity':\ line\.product_uom_qty\}\)
\ \ \ \ \ \ \ \ \ \
\ \ \ \ \ \ \ \ \ \ \ \ \#\ deduct\ the\ reserved\ quantity\ from\ the\ storage\ location
\ \ \ \ \ \ \ \ \ \ \ \ quants\ =\ env\['stock\.quant'\]\.search\(\[\('product_id','=',line\.product_id\.id\),\('location_id','=',\ line\.location_id\.id\),\('lot_id','=',\ False\)\],limit=1\)
\ \ \ \ \ \ \ \ \ \ \ \ if\ quants:
\ \ \ \ \ \ \ \ \ \ \ \ \ \ for\ quant\ in\ quants:
\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ quants\['quantity'\]\ =\ quant\.quantity\ \-\ line\.product_uom_qty
\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ quants\['reserved_quantity'\]\ =\ quant\.reserved_quantity\ \-\ line\.product_uom_qty

\ \ \ \ \ \ \ \ move\['is_done'\]\ =\ True
\ \ \ \ \ \ \ \ move\['state'\]\ =\ 'done'
\ \ \ \ \ \ \#else:
\ \ \ \ \ \ \#\ \ raise\ Warning\('Could\ not\ reserve\ '\ \+\ move\.product_id\.name\ \ \+\ ',\ at\ this\ time,\ stopping\ auto\-booking\.'\)
\ \
\ \ \ \ date_done\ =\ datetime\.datetime\.today\(\)
\ \ \ \ picking\['date_done'\]\ =\ datetime.datetime.strftime(date_done, '%Y-%m-%d %H:%M:%S')
picking['state'] = 'done'
picking.action_done()
picking.with_context(skip_backorder=True,skip_immediate=True).button_validate()

# process the material pickings for material consumption of the production order
record.action_assign()
0
Avatar
Discard
Peter Park

Sure, I'd be happy to review your code and provide feedback. Could you please provide a bit more information on what exactly the code is supposed to be doing? Specifically, what kind of inventory system are you using and how is the code interacting with it? Also, what are the various types of items that you are reserving? Once I have this information, I can better review your code and suggest any changes that might be needed.

Enjoying the discussion? Don't just read, join in!

Create an account today to enjoy exclusive features and engage with our awesome community!

Sign up
Related Posts Replies Views Activity
How to save exported to excel report to disk
12.04 Enterprise
Avatar
0
जन॰ 23
2568
Done and Cancelled MOs are not displayed
12.04 Enterprise
Avatar
Avatar
1
अग॰ 22
2417
How to Create MRP From Scrap in Odoo 15
mrp scrap Enterprise v15
Avatar
Avatar
1
सित॰ 23
2886
How to call a wizard prior to showing the tree view? Solved
treeview custom 12.04 Enterprise
Avatar
Avatar
1
नव॰ 22
9420
Odoo 17 Bom can't import with Produit / ID externe
mrp
Avatar
Avatar
Avatar
2
अग॰ 25
2050
कम्यूनिटी
  • ट्यूटोरियल्स
  • दस्तावेज़
  • फ़ोरम
ओपन सोर्स
  • डाउनलोड
  • Github
  • रनबॉट
  • अनुवाद
सेवाएं
  • Odoo.sh Hosting
  • सहायता
  • अपग्रेड
  • कस्टम डेवलपमेंट्स
  • शिक्षा
  • अकाउंटेंट खोजें
  • पार्टनर ढूंढें
  • पार्टनर बनें
हमारे बारे में
  • हमारी कंपनी
  • ब्रांड ऐसेट
  • संपर्क करें
  • नौकरियां
  • इवेंट
  • पॉडकास्ट
  • ब्लॉग
  • ग्राहक
  • लीगल • गोपनीयता
  • सुरक्षा
الْعَرَبيّة 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, बिज़नेस से जुड़े ऐप्लिकेशन का एक कलेक्शन है जो ओपन सोर्स पर आधारित है. इसमें आपकी कंपनी की हर ज़रूरत के लिए ऐप्लिकेशन हैं. जैसे, सीआरएम, ई-कॉमर्स, अकाउंटिंग, इन्वेंट्री, पॉइंट ऑफ़ सेल, प्रोजेक्ट मैनेजमेंट वगैरह.

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