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.

51 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
  28. reference string in A1 notation.
  29. """
  30. d = col // 26
  31. m = col % 26
  32. chr1 = "" # Most significant character in AA1
  33. if row_abs:
  34. row_abs = '$'
  35. else:
  36. row_abs = ''
  37. if col_abs:
  38. col_abs = '$'
  39. else:
  40. col_abs = ''
  41. if d > 0:
  42. chr1 = chr(ord('A') + d - 1)
  43. chr2 = chr(ord('A') + m)
  44. # Zero index to 1-index
  45. return col_abs + chr1 + chr2 + row_abs + str(row + 1)
  46. # vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: