首页 > 解决方案 > 使用带有 CJK 字符的 base64 格式的 SVG 图像生成 WeasyPrint 报告

问题描述

我正在使用Wea​​syPrint创建报告。我在向报告中添加 SVG 时遇到了困难。

附上我用 ( JsFiddle ) 提供 WeasyPrint 的 html 的一部分。

<html>
  <body>
    <img class='chart_image'
      src='data:image/svg+xml;charset=utf-8;base64,<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" style="font-family:'lucida grande', 'lucida sans unicode', arial, helvetica, sans-serif;font-size:12px;" xmlns="http://www.w3.org/2000/svg" width="600" height="200"><desc>Created with Highstock 4.2.2</desc><defs><clipPath id="highcharts-5"><rect x="0" y="0" width="534" height="103"></rect></clipPath></defs><rect x="0" y="0" width="600" height="200" strokeWidth="0" fill="#FFFFFF" class=" highcharts-background"></rect><g class="highcharts-grid" ></g><g class="highcharts-grid" ><path fill="none" d="M 10 62.5 L 544 62.5" stroke="#D8D8D8" stroke-width="1"  opacity="1"></path></g><g class="highcharts-axis" ><path fill="none" d="M 14.5 113 L 14.5 123" stroke="#C0D0E0" stroke-width="1" opacity="1"></path><path fill="none" d="M 89.5 113 L 89.5 123" stroke="#C0D0E0" stroke-width="1" opacity="1"></path><path fill="none" d="M 164.5 113 L 164.5 123" stroke="#C0D0E0" stroke-width="1" opacity="1"></path><path fill="none" d="M 239.5 113 L 239.5 123" stroke="#C0D0E0" stroke-width="1" opacity="1"></path><path fill="none" d="M 314.5 113 L 314.5 123" stroke="#C0D0E0" stroke-width="1" opacity="1"></path><path fill="none" d="M 389.5 113 L 389.5 123" stroke="#C0D0E0" stroke-width="1" opacity="1"></path><path fill="none" d="M 464.5 113 L 464.5 123" stroke="#C0D0E0" stroke-width="1" opacity="1"></path><path fill="none" d="M 539.5 113 L 539.5 123" stroke="#C0D0E0" stroke-width="1" opacity="1"></path><path fill="none" d="M 10 113.5 L 544 113.5" stroke="#C0D0E0" stroke-width="1" ></path></g><g class="highcharts-axis" ><text x="576"  text-anchor="middle" transform="translate(0,0) rotate(90 576 61.5)" class=" highcharts-yaxis-title" style="color:#707070;fill:#707070;" y="61.5">%</text></g><g class="highcharts-series-group" ><g class="highcharts-series highcharts-series-0"  transform="translate(10,10) scale(1 1)" clip-path="url(#highcharts-5)"><path fill="none" d="M 333.4179104477612 51.5 M 336.54345917471466 51.5 M 339.6690079016681 51.5 M 342.7945566286216 51.5 M 345.92010535557506 51.5 M 349.04565408252853 51.5 M 352.171202809482 51.5 M 355.29675153643547 51.5 M 358.42230026338893 51.5 M 364.67339771729587 51.5 M 386.55223880597015 51.5 M 399.054433713784 51.5 M 402.1799824407375 51.5 M 405.30553116769096 51.5 M 408.4310798946444 51.5 M 411.5566286215979 51.5 M 414.68217734855136 51.5 M 420.9332748024583 51.5 M 424.05882352941177 51.5 M 427.18437225636524 51.5 M 430.3099209833187 51.5 M 480.3187006145742 51.5 M 505.32309043020194 51.5 M 508.4486391571554 51.5" stroke="blue" stroke-width="1"  stroke-linejoin="round" stroke-linecap="round"></path></g><g class="highcharts-markers highcharts-series-0"  transform="translate(10,10) scale(1 1)" clip-path="none"></g><g class="highcharts-series highcharts-series-1"  transform="translate(10,10) scale(1 1)" clip-path="url(#highcharts-5)"><path fill="none" d="M 333.4179104477612 51.5 M 336.54345917471466 51.5 M 339.6690079016681 51.5 M 342.7945566286216 51.5 M 345.92010535557506 51.5 M 349.04565408252853 51.5 M 352.171202809482 51.5 M 355.29675153643547 51.5 M 358.42230026338893 51.5 M 364.67339771729587 51.5 M 386.55223880597015 51.5 M 399.054433713784 51.5 M 402.1799824407375 51.5 M 405.30553116769096 51.5 M 408.4310798946444 51.5 M 411.5566286215979 51.5 M 414.68217734855136 51.5 M 420.9332748024583 51.5 M 424.05882352941177 51.5 M 427.18437225636524 51.5 M 430.3099209833187 51.5 M 480.3187006145742 51.5 M 505.32309043020194 51.5 M 508.4486391571554 51.5" stroke="red" stroke-width="1"  stroke-linejoin="round" stroke-linecap="round"></path></g><g class="highcharts-markers highcharts-series-1"  transform="translate(10,10) scale(1 1)" clip-path="none"></g></g><g class="highcharts-legend"  transform="translate(223,146)"><g ><g><g class="highcharts-legend-item"  transform="translate(8,3)"><path fill="none" d="M 0 11 L 16 11" stroke="blue" stroke-width="1"></path><text x="21" style="color:#333333;font-size:12px;font-weight:bold;cursor:pointer;fill:#333333;" text-anchor="start"  y="15">毎日の外部湿度平均</text></g><g class="highcharts-legend-item"  transform="translate(8,17)"><path fill="none" d="M 0 11 L 16 11" stroke="red" stroke-width="1"></path><text x="21" y="15" style="color:#333333;font-size:12px;font-weight:bold;cursor:pointer;fill:#333333;" text-anchor="start" >毎日の内部湿度平均</text></g></g></g></g><g class="highcharts-axis-labels highcharts-xaxis-labels" ><text x="30" style="color:#606060;cursor:default;font-size:11px;fill:#606060;width:73px;text-overflow:clip;" text-anchor="middle" transform="translate(0,0)" y="132" opacity="1"><tspan>21. 1月</tspan></text><text x="90.24846356453028" style="color:#606060;cursor:default;font-size:11px;fill:#606060;width:73px;text-overflow:clip;" text-anchor="middle" transform="translate(0,0)" y="132" opacity="1"><tspan>22. 1月</tspan></text><text x="165.26163301141352" style="color:#606060;cursor:default;font-size:11px;fill:#606060;width:73px;text-overflow:clip;" text-anchor="middle" transform="translate(0,0)" y="132" opacity="1"><tspan>23. 1月</tspan></text><text x="240.27480245829676" style="color:#606060;cursor:default;font-size:11px;fill:#606060;width:73px;text-overflow:clip;" text-anchor="middle" transform="translate(0,0)" y="132" opacity="1"><tspan>24. 1月</tspan></text><text x="315.28797190518" style="color:#606060;cursor:default;font-size:11px;fill:#606060;width:73px;text-overflow:clip;" text-anchor="middle" transform="translate(0,0)" y="132" opacity="1"><tspan>25. 1月</tspan></text><text x="390.3011413520632" style="color:#606060;cursor:default;font-size:11px;fill:#606060;width:73px;text-overflow:clip;" text-anchor="middle" transform="translate(0,0)" y="132" opacity="1"><tspan>26. 1月</tspan></text><text x="465.31431079894645" style="color:#606060;cursor:default;font-size:11px;fill:#606060;width:73px;text-overflow:clip;" text-anchor="middle" transform="translate(0,0)" y="132" opacity="1"><tspan>27. 1月</tspan></text><text x="540.3274802458296" style="color:#606060;cursor:default;font-size:11px;fill:#606060;width:73px;text-overflow:clip;" text-anchor="middle" transform="translate(0,0)" y="132" opacity="1"><tspan>28. 1月</tspan></text></g><g class="highcharts-axis-labels highcharts-yaxis-labels" ><text x="559" style="color:#606060;cursor:default;font-size:11px;fill:#606060;width:188px;text-overflow:clip;" text-anchor="start" transform="translate(0,0)" y="66" opacity="1">0</text></g><g class="highcharts-tooltip"  style="cursor:default;padding:0;pointer-events:none;white-space:nowrap;" transform="translate(0,-9999)"><path fill="none" d="M 3.5 0.5 L 13.5 0.5 C 16.5 0.5 16.5 0.5 16.5 3.5 L 16.5 13.5 C 16.5 16.5 16.5 16.5 13.5 16.5 L 3.5 16.5 C 0.5 16.5 0.5 16.5 0.5 13.5 L 0.5 3.5 C 0.5 0.5 0.5 0.5 3.5 0.5"  stroke="black" stroke-opacity="0.049999999999999996" stroke-width="5" transform="translate(1, 1)"></path><path fill="none" d="M 3.5 0.5 L 13.5 0.5 C 16.5 0.5 16.5 0.5 16.5 3.5 L 16.5 13.5 C 16.5 16.5 16.5 16.5 13.5 16.5 L 3.5 16.5 C 0.5 16.5 0.5 16.5 0.5 13.5 L 0.5 3.5 C 0.5 0.5 0.5 0.5 3.5 0.5"  stroke="black" stroke-opacity="0.09999999999999999" stroke-width="3" transform="translate(1, 1)"></path><path fill="none" d="M 3.5 0.5 L 13.5 0.5 C 16.5 0.5 16.5 0.5 16.5 3.5 L 16.5 13.5 C 16.5 16.5 16.5 16.5 13.5 16.5 L 3.5 16.5 C 0.5 16.5 0.5 16.5 0.5 13.5 L 0.5 3.5 C 0.5 0.5 0.5 0.5 3.5 0.5"  stroke="black" stroke-opacity="0.15" stroke-width="1" transform="translate(1, 1)"></path><path fill="rgb(249, 249, 249)" fill-opacity=" .85" d="M 3.5 0.5 L 13.5 0.5 C 16.5 0.5 16.5 0.5 16.5 3.5 L 16.5 13.5 C 16.5 16.5 16.5 16.5 13.5 16.5 L 3.5 16.5 C 0.5 16.5 0.5 16.5 0.5 13.5 L 0.5 3.5 C 0.5 0.5 0.5 0.5 3.5 0.5"></path><text x="8"  style="font-size:12px;color:#333333;fill:#333333;" y="20"></text></g></svg>' />
  </body>
</html>

处理上述代码后,WeasyPrint 输出如下图所示:

在此处输入图像描述

我试图了解这是否是我可以修复的东西,也许可以通过在丢失的地方明确设置编码,或者 WeasyPrint 是否需要在内部修复。

知道如何进一步解决问题吗?

标签: encodingutf-8cairocjkweasyprint

解决方案


推荐阅读