Odoo中文社区可以通过以下三个域名访问:shine-it.net , odoocn.org,odoo.net.cn

原论坛用户的基本信息和发帖这里都予以保留,请注意:原论坛用户无需重新注册新用户,但是您的密码需要重置

开发人员可以登录gitter讨论组: http://gitter.im/odoo-china/Talk, 需要github账号

如果您登录系统碰到问题,请在微信公众号留言:

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



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

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

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

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

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



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

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

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

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

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


  • 管理员

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

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

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



  • 嗯. 正好你问到那个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]



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



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



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



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



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



  • 大神啊,刚好用上<br /><br />出现这个错误:UnicodeDecodeError: 'ascii' codec can't decode byte 0xc3 in position 0: ordinal not in range(128)<br /><br />一查Google:从:http://cn.openerp.cn/openerp-6的odt和rml报表/ <br /><br />来到这里了。<br /><br />感谢,感谢!


登录后回复
 

与 Odoo 中文社区 的连接断开,我们正在尝试重连,请耐心等待