使用 jQueryUI datepicker 和 php 以西班牙语获取一系列日期
Fetch a range of dates using jQueryUI datepicker and php, in Spanish
我正在尝试通过 2 个以前翻译成西班牙语的日期选择器来保存将由用户填写的日期范围。
问题是,当我在日期上使用 strtotime()
时,它会将月份作为日期,反之亦然。
示例:
我选择 2017 年 5 月 27 日和 2017 年,但 return 值是不正确的日期格式,因为月份是 27。如果我选择 2017 年 01 月 5 日,那么它在数组中显示为 05 月 01 日和2017 年。
这是我用来从输入文本中获取日期并生成日期之间的范围的函数
function takedates() {
if(isset($_POST['repS'])){
$dateStart = $_POST['txtdesde'];
$dateEnd = $_POST['txthasta'];
$fechaArray = generafechas($dateStart,$dateEnd);
}
function generafechas($date1,$date2){
$fecharray = array();
if (is_string($date1) === true){
$deit1 = strftime("%d-%m-%Y",strtotime($date1));
}
if (is_string($date2) === true){
$date2 = strftime("%d-%m-%Y",strtotime($date2));
}
do {
$fecharray[] = date("m-d-Y", $date1);
$date1 = strtotime("+1 day", $date1);
} while($date1 <= $date2);
return $fecharray;
}
?>
我的问题是:如何用西班牙日期格式的日期填充数组?
PS:我已经在我使用这些函数的文件中使用了 setLocale(LC_TIME,'es_ES')
,并且输入显示了这样的日期 "dd/mm/yyyy"
strtotime
在解析日期时间字符串时不会考虑您的语言环境。如果您使用由斜杠分隔的日期,则假定它是美式 m/d/y
。如果您使用由句点分隔的日期(如果年份是四位数字,则使用破折号),则假定它是世界其他地方的风格(d.m.y
或 d-m-Y
)。 (请注意,如果您仅使用两位数年份并使用破折号,PHP 将尝试将其解析为 y-m-d
。)
而不是 strtotime
,您应该使用 date-create-from-format
/ DateTime::createFromFormat
来获取 DateTime
对象,然后从中构建您的日期字符串。
基于评论的更新: 为了获得您想要的输出,您需要使用 intl
扩展的 IntlDateFormatter
class 来生成输出。
修改上面的代码(未经测试):
function generafechas($date1,$date2){
$fecharray = array();
if (is_string($date1) && is_string($date2)){
// These lines assume the input is formatted `day-month-year`,
// with 2-digit day and month, and 4-digit year.
$date1 = DateTime::createFromFormat('d-m-Y', $date1)
$date2 = DateTime::createFromFormat('d-m-Y', $date2)
} else {
throw new InvalidArgumentException('Must provide two date strings');
}
// Create the formatter
$formatter = IntlDateFormatter::create('es_ES', null, null, null, null, "d 'de' MMMM 'del' yyyy");
do {
// This line prints the first date in the format you chose above
$fecharray[] = $formatter->format($date1);
$date1->add(new DateInterval("P1D")); // `P1D` means "Duration of 1 Day" in the ISO 8601 standard
} while($date1 <= $date2);
return $fecharray;
}
如果您随数据一起提供区域设置,则可以根据需要更改 createFromFormat
中使用的格式字符串。
我正在尝试通过 2 个以前翻译成西班牙语的日期选择器来保存将由用户填写的日期范围。
问题是,当我在日期上使用 strtotime()
时,它会将月份作为日期,反之亦然。
示例: 我选择 2017 年 5 月 27 日和 2017 年,但 return 值是不正确的日期格式,因为月份是 27。如果我选择 2017 年 01 月 5 日,那么它在数组中显示为 05 月 01 日和2017 年。
这是我用来从输入文本中获取日期并生成日期之间的范围的函数
function takedates() {
if(isset($_POST['repS'])){
$dateStart = $_POST['txtdesde'];
$dateEnd = $_POST['txthasta'];
$fechaArray = generafechas($dateStart,$dateEnd);
}
function generafechas($date1,$date2){
$fecharray = array();
if (is_string($date1) === true){
$deit1 = strftime("%d-%m-%Y",strtotime($date1));
}
if (is_string($date2) === true){
$date2 = strftime("%d-%m-%Y",strtotime($date2));
}
do {
$fecharray[] = date("m-d-Y", $date1);
$date1 = strtotime("+1 day", $date1);
} while($date1 <= $date2);
return $fecharray;
}
?>
我的问题是:如何用西班牙日期格式的日期填充数组?
PS:我已经在我使用这些函数的文件中使用了 setLocale(LC_TIME,'es_ES')
,并且输入显示了这样的日期 "dd/mm/yyyy"
strtotime
在解析日期时间字符串时不会考虑您的语言环境。如果您使用由斜杠分隔的日期,则假定它是美式 m/d/y
。如果您使用由句点分隔的日期(如果年份是四位数字,则使用破折号),则假定它是世界其他地方的风格(d.m.y
或 d-m-Y
)。 (请注意,如果您仅使用两位数年份并使用破折号,PHP 将尝试将其解析为 y-m-d
。)
而不是 strtotime
,您应该使用 date-create-from-format
/ DateTime::createFromFormat
来获取 DateTime
对象,然后从中构建您的日期字符串。
基于评论的更新: 为了获得您想要的输出,您需要使用 intl
扩展的 IntlDateFormatter
class 来生成输出。
修改上面的代码(未经测试):
function generafechas($date1,$date2){
$fecharray = array();
if (is_string($date1) && is_string($date2)){
// These lines assume the input is formatted `day-month-year`,
// with 2-digit day and month, and 4-digit year.
$date1 = DateTime::createFromFormat('d-m-Y', $date1)
$date2 = DateTime::createFromFormat('d-m-Y', $date2)
} else {
throw new InvalidArgumentException('Must provide two date strings');
}
// Create the formatter
$formatter = IntlDateFormatter::create('es_ES', null, null, null, null, "d 'de' MMMM 'del' yyyy");
do {
// This line prints the first date in the format you chose above
$fecharray[] = $formatter->format($date1);
$date1->add(new DateInterval("P1D")); // `P1D` means "Duration of 1 Day" in the ISO 8601 standard
} while($date1 <= $date2);
return $fecharray;
}
如果您随数据一起提供区域设置,则可以根据需要更改 createFromFormat
中使用的格式字符串。