PHP 8.1.0 RC 2 available for testing

DateTime::setISODate

date_isodate_set

(PHP 5 >= 5.2.0, PHP 7, PHP 8)

DateTime::setISODate -- date_isodate_set设置 ISO 日期

说明

面向对象风格

public DateTime::setISODate(int $year, int $week, int $dayOfWeek = 1): DateTime

过程化风格

date_isodate_set(
    DateTime $object,
    int $year,
    int $week,
    int $dayOfWeek = 1
): DateTime

以 ISO 8601 规范的格式设置日期, 使用周和日的偏移量作为参数,而不是使用月和日。

参数

object

仅过程化风格:由 date_create() 返回的 DateTime 类型的对象。此函数会修改这个对象。

year

年份。

week

周。

dayOfWeek

从周的第一天计算,日在一周内的偏移量。

返回值

返回被修改的 DateTime 对象, 或者在失败时返回 false.

范例

示例 #1 DateTime::setISODate() 例程

面向对象风格

<?php
$date 
= new DateTime();

$date->setISODate(20082);
echo 
$date->format('Y-m-d') . "\n";

$date->setISODate(200827);
echo 
$date->format('Y-m-d') . "\n";
?>

过程化风格

<?php
$date 
date_create();

date_isodate_set($date20082);
echo 
date_format($date'Y-m-d') . "\n";

date_isodate_set($date200827);
echo 
date_format($date'Y-m-d') . "\n";
?>

以上例程会输出:

2008-01-07
2008-01-13

示例 #2 超出有效范围的部分,会加到上一级

<?php
$date 
= new DateTime();

$date->setISODate(200827);
echo 
$date->format('Y-m-d') . "\n";

$date->setISODate(200828);
echo 
$date->format('Y-m-d') . "\n";

$date->setISODate(2008537);
echo 
$date->format('Y-m-d') . "\n";
?>

以上例程会输出:

2008-01-13
2008-01-14
2009-01-04

示例 #3 找出来某个周所属的月份

<?php
$date 
= new DateTime();
$date->setISODate(200814);
echo 
$date->format('n');
?>

以上例程会输出:

3

参见

add a note add a note

User Contributed Notes

There are no user contributed notes for this page.
To Top