0

我有一个英文的博客存档,我希望用瑞典语显示月份。我已经搜索并尝试了类似问题的答案,但没有任何效果。有人可以帮忙吗?

<?php
include 'includes/db_connection.php';
setlocale(LC_ALL, 'sv_SE');
$result = mysql_query("SELECT FROM_UNIXTIME(timestamp, '%M %Y') AS get_month, COUNT(*) AS entries FROM php_blog GROUP BY get_month ORDER BY timestamp DESC"); ?>

<ul class="archive_list">
<br><br><br><br>
<ul class="archive_ul">
<?php
while ($row = mysql_fetch_array($result)) {
setlocale(LC_ALL, 'sv_SE');

$get_month = $row['get_month'];
$entries = $row['entries'];
echo "<li><a href=\"archive.php?month=" . $get_month . "\">" . $get_month . "</a></li>";
}


//setlocale(LC_ALL, 'sv_SE');
//echo utf8_encode (strftime("%A %e %B %Y"));

?>

因此,在下面的链接中,我希望以瑞典语显示月份,并且我正在使用 get_month 从我的数据库中提取它。有任何想法吗?我真的只需要要翻译的链接中显示的月份名称。谢谢!

4

2 回答 2

1

setlocale()设置 PHP 的语言环境,但月份名称是由 MySQL 生成的,它有自己的设置。尝试使用以下命令更新 MySQL 的语言环境:

mysql_query("SET lc_time_names = 'sv_SE'");

(这应该在您的声明setlocale()之前替换您的第一个实例SELECT ...

注意:mysql_*功能已贬值,您可能需要考虑mysqli_*使用

于 2014-04-03T13:14:39.977 回答
0

如果只有月份,请将其放入包含月份索引的数组中,并在 12 个月内使用谷歌翻译。

$swedish_months = array('Januari','Februari','Mars','April','Maj','Juni','Juli','Augusti','September','Oktober','november','December');

将其作为索引 0

所以当你抓住它时,$swedish_months[$get_month] 将进入索引。除非 get_month 不是数字,否则您需要相应地调整索引查找。(IE:array('00'=>'Januari',...)

于 2014-04-03T13:13:21.393 回答