OCA reporting engine fork for dev and update.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

50 lines
1.7 KiB

  1. # -*- encoding: utf-8 -*-
  2. ##############################################################################
  3. #
  4. # OpenERP, Open Source Management Solution
  5. #
  6. # Copyright (c) 2014 Noviat nv/sa (www.noviat.com). All rights reserved.
  7. #
  8. # This program is free software: you can redistribute it and/or modify
  9. # it under the terms of the GNU Affero General Public License as
  10. # published by the Free Software Foundation, either version 3 of the
  11. # License, or (at your option) any later version.
  12. #
  13. # This program is distributed in the hope that it will be useful,
  14. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. # GNU Affero General Public License for more details.
  17. #
  18. # You should have received a copy of the GNU Affero General Public License
  19. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  20. #
  21. ##############################################################################
  22. def _render(code):
  23. return compile(code, '<string>', 'eval')
  24. def rowcol_to_cell(row, col, row_abs=False, col_abs=False):
  25. # Code based upon utils from xlwt distribution
  26. """
  27. Convert numeric row/col notation to an Excel cell reference string in A1 notation.
  28. """
  29. d = col // 26
  30. m = col % 26
  31. chr1 = "" # Most significant character in AA1
  32. if row_abs:
  33. row_abs = '$'
  34. else:
  35. row_abs = ''
  36. if col_abs:
  37. col_abs = '$'
  38. else:
  39. col_abs = ''
  40. if d > 0:
  41. chr1 = chr(ord('A') + d - 1)
  42. chr2 = chr(ord('A') + m)
  43. # Zero index to 1-index
  44. return col_abs + chr1 + chr2 + row_abs + str(row + 1)
  45. # vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: