Перейти к содержимому
Odoo Меню
  • Войти
  • Попробовать бесплатно
  • Модули
    Финансы
    • Бухгалтерия
    • Выставление счетов
    • Расходы
    • Таблицы
    • Документооборот
    • Подпись
    Продажи
    • CRM
    • Продажи
    • POS Магазин
    • POS Ресторан
    • Подписки
    • Аренда
    Вебсайты
    • Конструктор вебсайтов
    • eCommerce
    • Блог
    • Форум
    • Онлайн-чат
    • Электронное обучение
    Логистика
    • Склад
    • Производство
    • PLM
    • Закупки
    • Обслуживание
    • Качество
    Отдел кадров
    • Сотрудники
    • Подбор персонала
    • Отпуска
    • Оценка персонала
    • Реферальная программа
    • Автопарк
    Маркетинг
    • SMM
    • E-mail рассылки
    • СМС рассылки
    • Мероприятия
    • Автоматизация маркетинга
    • Опросы
    Услуги
    • Проекты
    • Табели
    • Выездной сервис
    • Поддержка
    • Планирование
    • Встречи
    Продуктивность
    • Обсуждения
    • Согласование
    • IoT
    • VoIP-телефония
    • Knowledge
    • WhatsApp
    Сторонние приложения Модуль Студия Odoo Платформа Odoo Cloud
  • Индустрии
    Розничная торговля
    • Книжный магазин
    • Магазин одежды
    • Мебельный магазин
    • Продуктовый магазин
    • Строительный магазин
    • Магазин игрушек
    Гостинично-ресторанный бизнес
    • Бар и паб
    • Ресторан
    • Фастфуд
    • Гостевой дом
    • Дистрибьютор напитков
    • Отель
    Недвижимость
    • Агентство недвижимости
    • Архитектурное бюро
    • Строительство
    • Управление недвижимостью
    • Ландшафтный дизайн
    • Товарищество собственников жилья
    Консалтинг
    • Бухгалтерская фирма
    • Партнер Odoo
    • Маркетинговое агентство
    • Юридическая фирма
    • Подбор персонала
    • Аудиторское бюро
    Производство
    • Текстиль
    • Металл
    • Мебель
    • Продукты питания
    • Пивоварня
    • Корпоративные сувениры
    Здоровье и фитнес
    • Спортивный комплекс
    • Магазин оптики
    • Фитнес-клуб
    • Велнес-центр
    • Аптека
    • Салон красоты
    Услуги
    • Специалист по бытовым услугам
    • Продажа и обслуживание IT-оборудования
    • Солнечные энергосистемы
    • Производство обуви
    • Клининг
    • Системы ОВКВ
    Прочее
    • Некоммерческая организация
    • Консалтинг в сфере устойчивого развития
    • Аренда рекламных щитов
    • Бизнес по фотосъемке
    • Прокат велосипедов
    • Реселлер программного обеспечения
    Все индустрии
  • Community
    Обучение
    • Видео уроки
    • Документация
    • Сертификация
    • Тренинг
    • Блог
    • Подкаст
    Образование и развитие
    • Образовательная программа
    • Деловая игра Scale Up!
    • Экскурсия в офис Odoo
    ПО
    • Скачать
    • Сравнить версии
    • Релизы
    Сотрудничество
    • 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:

  • CRM
  • e-Commerce
  • Бухгалтерия
  • Склад
  • PoS
  • Проекты
  • MRP
All apps
Чтобы взаимодействовать с сообществом, необходимо зарегистрироваться.
Все посты Люди Значки
Теги (Смотреть все)
odoo accounting v14 pos v15
Об этом форуме
Чтобы взаимодействовать с сообществом, необходимо зарегистрироваться.
Все посты Люди Значки
Теги (Смотреть все)
odoo accounting v14 pos v15
Об этом форуме
Помощь

AttributeError: 'int' object has no attribute 'id'

Подписаться

Получайте уведомления о появлении активности в этом посте

Этот вопрос был отмечен
3 Ответы
16664 Представления
Аватар
Afthab



Traceback (most recent call last): File "/odoo/odoo-server/odoo/http.py", line 640, in _handle_exception return super(JsonRequest, self)._handle_exception(exception) File "/odoo/odoo-server/odoo/http.py", line 677, in dispatch result = self._call_function(**self.params) File "/odoo/odoo-server/odoo/http.py", line 333, in _call_function return checked_call(self.db, *args, **kwargs) File "/odoo/odoo-server/odoo/service/model.py", line 101, in wrapper return f(dbname, *args, **kwargs) File "/odoo/odoo-server/odoo/http.py", line 326, in checked_call result = self.endpoint(*a, **kw) File "/odoo/odoo-server/odoo/http.py", line 935, in __call__ return self.method(*args, **kw) File "/odoo/odoo-server/odoo/http.py", line 506, in response_wrap response = f(*args, **kw) File "/odoo/odoo-server/addons/web/controllers/main.py", line 1154, in load action = request.env[action_type].browse([action_id]).read() File "/odoo/odoo-server/odoo/addons/base/ir/ir_actions.py", line 317, in read result = super(IrActionsActWindow, self).read(fields, load=load) File "/odoo/odoo-server/odoo/models.py", line 3018, in read values[name] = field.convert_to_read(record[name], record, use_name_get) File "/odoo/odoo-server/odoo/models.py", line 5208, in __getitem__ return self._fields[key].__get__(self, type(self)) File "/odoo/odoo-server/odoo/fields.py", line 910, in __get__ self.determine_value(record) File "/odoo/odoo-server/odoo/fields.py", line 1022, in determine_value self.compute_value(recs) File "/odoo/odoo-server/odoo/fields.py", line 976, in compute_value self._compute_value(records) File "/odoo/odoo-server/odoo/fields.py", line 967, in _compute_value getattr(records, self.compute)() File "/odoo/odoo-server/odoo/addons/base/ir/ir_actions.py", line 277, in _compute_search_view fvg = self.env[act.res_model].fields_view_get(act.search_view_id.id, 'search') File "/odoo/odoo-server/addons/hr_uae/models/hr_employee.py", line 52, in fields_view_get expiry_tree_emirates_view_id = get_view_id('view_expiry_emirates_reminder_employee_tree', 'hr.employee.tree').id AttributeError: 'int' object has no attribute 'id'    





my  hr_employee.py file is


# -*- coding: utf-8 -*-

#

# OpenERP, Open Source Management Solution

#

# This program is free software: you can redistribute it and/or modify

# it under the terms of the GNU Affero General Public License as

# published by the Free Software Foundation, either version 3 of the

# License, or (at your option) any later version.

#

# This program is distributed in the hope that it will be useful,

# but WITHOUT ANY WARRANTY; without even the implied warranty of

# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the

# GNU Affero General Public License for more details.

#

# You should have received a copy of the GNU Affero General Public License

# along with this program. If not, see <http://www.gnu.org/licenses/>.

#

from odoo import models, fields, api, _

from datetime import datetime, timedelta

from odoo.exceptions import except_orm, RedirectWarning

from lxml import etree

class HrEmployee(models.Model):

_inherit = 'hr.employee'

@api.model

def fields_view_get(self, view_id=None, view_type=False, toolbar=False, submenu=False):

res = super(HrEmployee, self).fields_view_get(view_id=view_id, view_type=view_type, toolbar=toolbar,

submenu=submenu)

today = datetime.now().strftime('%Y-%m-%d')

tomorrow = (datetime.now() + timedelta(days=1)).strftime('%Y-%m-%d')

day_b4_30 = (datetime.now() + timedelta(days=30)).strftime('%Y-%m-%d')

day_b4_60 = (datetime.now() + timedelta(days=60)).strftime('%Y-%m-%d')

today_str = "'" + today + "'"

tomorrow_str = "'" + tomorrow + "'"

day_b4_30_str = "'" + day_b4_30 + "'"

day_b4_60_str = "'" + day_b4_60 + "'"

def get_view_id(xid, name):

try:

return self.env.ref('archi_custom.' + xid)

except ValueError:

view = self.env['ir.ui.view'].search([('name', '=', name)], limit=1)

if not view:

return False

return view.id

expiry_tree_emirates_view_id = get_view_id('view_expiry_emirates_reminder_employee_tree', 'hr.employee.tree').id

expiry_tree_passport_view_id = get_view_id('view_expiry_passport_reminder_employee_tree', 'hr.employee.tree').id

expiry_tree_license_view_id = get_view_id('view_expiry_license_reminder_employee_tree', 'hr.employee.tree').id

expiry_tree_health_card_view_id = get_view_id('view_expiry_health_card_reminder_employee_tree', 'hr.employee.tree').id

expiry_tree_visa_view_id = get_view_id('view_expiry_visa_reminder_employee_tree', 'hr.employee.tree').id

expiry_tree_insurance_view_id = get_view_id('view_expiry_insurance_reminder_employee_tree', 'hr.employee.tree').id

expiry_tree_work_permit_view_id = get_view_id('view_expiry_work_permit_reminder_employee_tree', 'hr.employee.tree').id

if expiry_tree_emirates_view_id:

if expiry_tree_emirates_view_id == view_id:

doc = etree.XML(res['arch'])

for node in doc.xpath("//tree"):

color_string = "grey:emirates_expiry_date < " + today_str + " ;" + "red:emirates_expiry_date == " + today_str + " ;" + "orange:emirates_expiry_date >=" + tomorrow_str + "and emirates_expiry_date <=" + day_b4_30_str + " ;"

color_string = color_string + "blue:emirates_expiry_date >" + day_b4_30_str + "and emirates_expiry_date <=" + day_b4_60_str + " ;" + "green:emirates_expiry_date > " + day_b4_60_str + " ;"

node.set('colors', color_string)

res['arch'] = etree.tostring(doc)

if expiry_tree_passport_view_id:

if expiry_tree_passport_view_id == view_id:

doc = etree.XML(res['arch'])

for node in doc.xpath("//tree"):

color_string = "grey:passport_expiry_date < " + today_str + " ;" + "red:passport_expiry_date == " + today_str + " ;" + "orange:passport_expiry_date >=" + tomorrow_str + "and passport_expiry_date <=" + day_b4_30_str + " ;"

color_string = color_string + "blue:passport_expiry_date >" + day_b4_30_str + "and passport_expiry_date <=" + day_b4_60_str + " ;" + "green:passport_expiry_date > " + day_b4_60_str + " ;"

node.set('colors', color_string)

res['arch'] = etree.tostring(doc)

if expiry_tree_license_view_id:

if expiry_tree_license_view_id == view_id:

doc = etree.XML(res['arch'])

for node in doc.xpath("//tree"):

color_string = "grey:license_expiry_date < " + today_str + " ;" + "red:license_expiry_date == " + today_str + " ;" + "orange:license_expiry_date >=" + tomorrow_str + "and license_expiry_date <=" + day_b4_30_str + " ;"

color_string = color_string + "blue:license_expiry_date >" + day_b4_30_str + "and license_expiry_date <=" + day_b4_60_str + " ;" + "green:license_expiry_date > " + day_b4_60_str + " ;"

node.set('colors', color_string)

res['arch'] = etree.tostring(doc)

if expiry_tree_health_card_view_id:

if expiry_tree_health_card_view_id == view_id:

doc = etree.XML(res['arch'])

for node in doc.xpath("//tree"):

color_string = "grey:health_card_expiry_date < " + today_str + " ;" + "red:health_card_expiry_date == " + today_str + " ;" + "orange:health_card_expiry_date >=" + tomorrow_str + "and health_card_expiry_date <=" + day_b4_30_str + " ;"

color_string = color_string + "blue:health_card_expiry_date >" + day_b4_30_str + "and health_card_expiry_date <=" + day_b4_60_str + " ;" + "green:health_card_expiry_date > " + day_b4_60_str + " ;"

node.set('colors', color_string)

res['arch'] = etree.tostring(doc)

if expiry_tree_visa_view_id:

if expiry_tree_visa_view_id == view_id:

doc = etree.XML(res['arch'])

for node in doc.xpath("//tree"):

color_string = "grey:visa_expiry_date < " + today_str + " ;" + "red:visa_expiry_date == " + today_str + " ;" + "orange:visa_expiry_date >=" + tomorrow_str + "and visa_expiry_date <=" + day_b4_30_str + " ;"

color_string = color_string + "blue:visa_expiry_date >" + day_b4_30_str + "and visa_expiry_date <=" + day_b4_60_str + " ;" + "green:visa_expiry_date > " + day_b4_60_str + " ;"

node.set('colors', color_string)

res['arch'] = etree.tostring(doc)

if expiry_tree_insurance_view_id:

if expiry_tree_insurance_view_id == view_id:

doc = etree.XML(res['arch'])

for node in doc.xpath("//tree"):

color_string = "grey:insurance_expiry_date < " + today_str + " ;" + "red:insurance_expiry_date == " + today_str + " ;" + "orange:insurance_expiry_date >=" + tomorrow_str + "and insurance_expiry_date <=" + day_b4_30_str + " ;"

color_string = color_string + "blue:insurance_expiry_date >" + day_b4_30_str + "and insurance_expiry_date <=" + day_b4_60_str + " ;" + "green:insurance_expiry_date > " + day_b4_60_str + " ;"

node.set('colors', color_string)

res['arch'] = etree.tostring(doc)

if expiry_tree_work_permit_view_id:

if expiry_tree_work_permit_view_id == view_id:

doc = etree.XML(res['arch'])

for node in doc.xpath("//tree"):

color_string = "grey:work_permit_expiry_date < " + today_str + " ;" + "red:work_permit_expiry_date == " + today_str + " ;" + "orange:work_permit_expiry_date >=" + tomorrow_str + "and work_permit_expiry_date <=" + day_b4_30_str + " ;"

color_string = color_string + "blue:work_permit_expiry_date >" + day_b4_30_str + "and work_permit_expiry_date <=" + day_b4_60_str + " ;" + "green:work_permit_expiry_date > " + day_b4_60_str + " ;"

node.set('colors', color_string)

res['arch'] = etree.tostring(doc)

return res

health_card_expiry_date = fields.Date('Health Card Expiry Date')

health_card_id = fields.Char('Health Card ID')

camp = fields.Char('Camp')

fleet = fields.Char('Fleet')

emirates_expiry_date = fields.Date('Emirates ID Expiry Date')

emirates_id = fields.Char('Emirates ID')

license_type = fields.Selection([('Private', 'Private'),

('General', 'General'),

('Public', 'Public'),

('MotorCycle', 'MotorCycle')

], 'License Type')

license_expiry_date = fields.Date('License Expiry Date')

sponsor = fields.Char('Sponsor')

visa_expiry_date = fields.Date('Visa Expiry Date')

insurance = fields.Char('Insurance Name')

insurance_type = fields.Char('Insurance Type')

insurance_expiry_date = fields.Date('Insurance Expiry Date')

work_permit_expiry_date = fields.Date('Work Permit Expiry Date')

passport_expiry_date = fields.Date('Passport Expiry Date')

issue_register_ids = fields.One2many('hr.issue.register', 'employee_id', "Issue Register")

salary_increment_ids = fields.One2many('hr.salary.increment', 'employee_id', 'Salary Increments')

vehicle_fine_ids = fields.One2many('vehicle.fine', 'employee_id', 'Vehicle Fine')

class HrIssueRegister(models.Model):

_name = 'hr.issue.register'

item_id = fields.Many2one('issue.item', 'Item', required=True)

issue_date = fields.Date('Issue Date')

employee_id = fields.Many2one('hr.employee', 'Employee', ondelete='cascade')

class IssueItem(models.Model):

_name = 'issue.item'

name = fields.Char('Name')

class HrSalaryIncrement(models.Model):

_name = 'hr.salary.increment'

increment_date = fields.Date('Increment Date')

base_salary = fields.Float('Base Salary')

increment = fields.Float('Increment')

employee_id = fields.Many2one('hr.employee', 'Employee', ondelete='cascade')

class VehicleFine(models.Model):

_name = 'vehicle.fine'

name = fields.Char('Name')

employee_id = fields.Many2one('hr.employee', 'Employee', ondelete='cascade')

fine_date = fields.Date('Date', required=True)

fine_type = fields.Char('Fine Type')

fine_amount = fields.Float('Amount', required=True)

is_paid = fields.Boolean('Is Paid')

0
Аватар
Отменить
Аватар
Megha Patel
Лучший ответ

Afthab

the line which is throwing error is giving the id and it is already in integer and you are trying to access its id which is inappropriate

  • firstly browse it and then use id

            expiry_tree_emirates_view_id = get_view_id('view_expiry_emirates_reminder_employee_tree', 'hr.employee.tree')

            view_id = self.env["ir.ui.view"].browse(expiry_tree_emirates_view_id).id


Thank You


0
Аватар
Отменить
Аватар
Sehrish
Лучший ответ

You are trying to get column name from integer field. For example you have a int type variable (abc) and you get something using (.) dot notation: abc.getting_something. Instead of int field get some field through object like hr(1).id

0
Аватар
Отменить
Аватар
Jothimani Rajagopal
Лучший ответ

Hello Afthab,

The following codes returns only database id that is Integer not recordset. that's why the error is came.

expiry_tree_emirates_view_id = get_view_id('view_expiry_emirates_reminder_employee_tree', 'hr.employee.tree').id 

You can try like this for all occurrences 

expiry_tree_emirates_view_id = get_view_id('view_expiry_emirates_reminder_employee_tree', 'hr.employee.tree')

0
Аватар
Отменить
Не оставайтесь в стороне – присоединяйтесь к обсуждению!

Создайте аккаунт сегодня, чтобы получить доступ к эксклюзивным функциям и стать частью нашего замечательного сообщества!

Регистрация
Сообщество
  • Видео уроки
  • Документация
  • Форум
Открытый исходный код
  • Скачать
  • Github
  • Runbot
  • Перевод
Услуги
  • Хостинг Odoo.sh
  • Поддержка
  • Обновление
  • Индивидуальные решения по доработке
  • Образование
  • Найти бухгалтера
  • Найти партнера
  • Стать партнером
О нас
  • Наша компания
  • Активы бренда
  • Cвяжитесь с нами
  • Вакансии
  • Мероприятия
  • Подкаст
  • Блог
  • Клиенты
  • Правовые документы • Конфиденциальность
  • Безопасность
الْعَرَبيّة 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 – это набор бизнес-модулей с открытым исходным кодом, который закроет все потребности вашей компании: CRM, E-commerce, Бухгалтерия, Склад, POS, управление проектами и др.

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