跳转至内容
  • 版块
  • 标签
  • 热门
  • 用户
  • 群组
皮肤
  • Light
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • 默认(Flatly)
  • 不使用皮肤
折叠

Odoo 中文社区

  1. 主页
  2. 版块
  3. Odoo 开发与实施交流
  4. 关于 sxw2rml 使用 sxw 文件做报表模板的一些测试

关于 sxw2rml 使用 sxw 文件做报表模板的一些测试

已定时 已固定 已锁定 已移动 Odoo 开发与实施交流
10 帖子 6 发布者 12.3k 浏览
  • 从旧到新
  • 从新到旧
  • 最多赞同
登录后回复
此主题已被删除。只有拥有主题管理权限的用户可以查看。
  • mrshellyM 离线
    mrshellyM 离线
    mrshelly
    写于 最后由 编辑
    #1

    因为写一个模块, 要涉及到报表应用了.. 米办法, 就想一下报表的使用吧.
    按前面的分析.. 最推荐就是 sxw2rml 就是用 OpenOffice 的1.0 (.sxw 文件) 制作的报表模板. 转化为 OE内部使用的 rml 格式文件.

    当然, 你愿意直接使用 rml 格式. 可以跳过.

    现在使用中文报表(报表中 有中文内容, 以及中文字体) 的主要问题就是模板处理时的编码问题.

    对于字体, 不太好处理, 所以,只需要把 sxw 文件中的 中文字体名替换为英文字体名就行了.

    怎么弄, 还是看图吧...:

    1 条回复 最后回复
    0
    • JoshuaJ 离线
      JoshuaJ 离线
      Joshua 管理员
      写于 最后由 编辑
      #2

      水哥出手...顶...正好做到报表,:lol

      P.S 经测试十分方便,而且5.0.7的library好像缺少了某些对与report_desginer的支持模块,这样使用脚本更快捷安全

      [[i] 本帖最后由 Joshua 于 2010-3-30 16:44 编辑 [/i]]

      【上海先安科技】(joshua AT openerp.cn),欢迎关注公众号:openerp_cn

      1 条回复 最后回复
      0
      • mrshellyM 离线
        mrshellyM 离线
        mrshelly
        写于 最后由 编辑
        #3

        嗯. 正好你问到那个test.py

        我就发出来.. 有用的就拿去用... 我觉得 报表又不是经常修改.. 能这样用脚本处理就用脚本处理好了.[code]
        import tiny_sxw2rml
        import base64
        import StringIO

        fp = file(r'sxw文件路径及文件名', 'rb')
        fcontent = fp.read()
        fp.close()

        #fc = base64.encodestring(fcontent)
        sxwval = StringIO.StringIO(fcontent)
        fp = file(r'D:Program FilesOpenERPServeraddonsbase_report_designerwizardtiny_sxw2rmlnormalized_oo2rml.xsl', 'rb')
        s = str(tiny_sxw2rml.sxw2rml(sxwval, xsl=fp.read()))
        fp.close()

        fp = file(r'生成的rml文件路径及文件名', 'wb+')
        fp.write(s)
        fp.close()

        sys.exit(1)
        [/code]

        1 条回复 最后回复
        0
        • L 离线
          L 离线
          lux
          写于 最后由 编辑
          #4

          哇哈哈,今天我才在Q群里问,回家后看一下就找到想要的东西,蟹蟹SHELLY~:handshake

          1 条回复 最后回复
          0
          • X 离线
            X 离线
            xtjie
            写于 最后由 编辑
            #5

            不知版主是怎么知道这样的方法,弄了半天,最后按此方法通过。一开始以为是有汉字的缘故,改了还不行。原来在文件的内部。

            1 条回复 最后回复
            0
            • mrshellyM 离线
              mrshellyM 离线
              mrshelly
              写于 最后由 编辑
              #6

              这办法我一般不轻易告诉别人...:D

              1 条回复 最后回复
              0
              • X 离线
                X 离线
                xtjie
                写于 最后由 编辑
                #7

                版主现在还用这种方法做报表吗?

                1 条回复 最后回复
                0
                • C 离线
                  C 离线
                  ccdos
                  写于 最后由 编辑
                  #8

                  还没开始学习做报表,先瞧瞧

                  1 条回复 最后回复
                  0
                  • W 离线
                    W 离线
                    winson97
                    写于 最后由 编辑
                    #9

                    大神啊,刚好用上

                    出现这个错误:UnicodeDecodeError: 'ascii' codec can't decode byte 0xc3 in position 0: ordinal not in range(128)

                    一查Google:从:http://cn.openerp.cn/openerp-6的odt和rml报表/

                    来到这里了。

                    感谢,感谢!

                    1 条回复 最后回复
                    0

                    • 登录

                    • 没有帐号? 注册

                    • 登录或注册以进行搜索。
                    • 第一个帖子
                      最后一个帖子
                    0
                    • 版块
                    • 标签
                    • 热门
                    • 用户
                    • 群组