FPDF utf-8编码 (如何)

2024-04-24 04:04:22 发布

您现在位置:Python中文网/ 问答频道 /正文


Tags: python
3条回答

这个问题有一个非常简单的解决办法。

在文件fpdf.php中,转到如下行:

if($txt!=='')
{

这是我的fpdf版本中的第648行。 插入以下代码行:

$txt = iconv('utf-8', 'cp1252', $txt);

(代码行上方)

if($align=='R')

这适用于所有德语特殊字符,也适用于希腊特殊字符。否则,只需将cp1252替换为所需的相应字母表。您可以在这里看到所有支持的字符:http://en.wikipedia.org/wiki/Windows-1252

我在这里看到了解决方案:http://fudforum.org/forum/index.php?t=msg&goto=167345 请使用我上面的示例代码,因为原始作者忘记在utf和8之间插入破折号。

希望以上是有帮助的。

大安

还有一个正式的UTF-8版本的FPDF称为tFPDF http://www.fpdf.org/en/script/script92.php

您可以轻松地从原始FPDF切换,只需确保您也使用了上面链接或“我的代码”中的示例所示的unicode字体:

<?php

//this is a UTF-8 file, we won't need any encode/decode/iconv workarounds

//define the path to the .ttf files you want to use
define('FPDF_FONTPATH',"../fonts/");
require('tfpdf.php');

$pdf = new tFPDF();
$pdf->AddPage();

// Add Unicode fonts (.ttf files)
$fontName = 'Helvetica';
$pdf->AddFont($fontName,'','HelveticaNeue LightCond.ttf',true);
$pdf->AddFont($fontName,'B','HelveticaNeue MediumCond.ttf',true);

//now use the Unicode font in bold
$pdf->SetFont($fontName,'B',12);

//anything else is identical to the old FPDF, just use Write(),Cell(),MultiCell()... 
//without any encoding trouble
$pdf->Cell(100,20, "Some UTF-8 String");

//...
?>

我认为使用它比到处散播utf8_decode()要优雅得多,直接在AddFont()中使用.ttf文件也是一个好处。

这里的任何其他答案都只是一种避免或解决问题的方法,对于一个最新的项目来说,避免使用UTF-8并不是一个真正的选择。

在FPDF的基础上也有类似mPDF或TCPDF(以及其他)的替代方案,但是提供高级功能,支持UTF-8,并且可以解释HTML代码(当然,由于没有直接的方法将HTML转换为PDF,因此受到限制)。 大多数FPDF代码都可以直接在这些库中使用,因此迁移代码非常容易。

https://github.com/mpdf/mpdfhttp://www.tcpdf.org/

不要使用UTF-8编码。标准FPDF字体使用ISO-8859-1或Windows-1252。可以使用utf8_decode()执行到ISO-8859-1的转换: $str = utf8_decode($str); 但一些字符,如欧元,将不会被正确翻译。如果iconv扩展可用,正确的方法如下: $str = iconv('UTF-8', 'windows-1252', $str);

相关问题 更多 >