定制 ecommit/frequency-generator 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

ecommit/frequency-generator

最新稳定版本:v2.1.1

Composer 安装命令:

composer require ecommit/frequency-generator

包简介

Get the next date by frequency.

README 文档

README

Get the next date (DateTime object) by frequency.

Tests

Installation

To install frequency-generator with Composer just run :

$ composer require ecommit/frequency-generator

Usage

Create generator

use Ecommit\FrequencyGenerator\FrequencyGenerator;

$generator = new FrequencyGenerator();

Frequency "every day"

//Every day at 08:00:00 and 10:00:00
$dateTimeObject = $generator->nextInEveryDay([new \DateTime('10:00:00'), new \DateTime('08:00:00')]);

Arguments :

  • array $times Times (Array of DateTime or DateTimeImmutable objects). Default: only 00:00:00

Frequency "every week"

//Every monday (at 08:00:00 and 10:00:00) and tuesday (at 08:00:00 and 10:00:00)
$dateTimeObject = $generator->nextInEveryWeek([1, 2], [new \DateTime('10:00:00'), new \DateTime('08:00:00')]);

Arguments :

  • array $days Array of days in week (integers). (1=Monday => 7=Sunday). Default: Only 1 (monday)
  • array $times Times (Array of DateTime or DateTimeImmutable objects). Default: only 00:00:00

Frequency "every month"

//Every 1st (at 08:00:00 and 10:00:00) and 2nd (at 08:00:00 and 10:00:00)
$dateTimeObject = $generator->nextInEveryMonth([1, 2], [new \DateTime('10:00:00'), new \DateTime('08:00:00')]);

Arguments :

  • array $days Array of days in month (integers). (1=>31). Default: Only 1 (1st)
  • array $times Times (Array of DateTime or DateTimeImmutable objects). Default: only 00:00:00

Frequency "every quart"

//Every 1st and 15th February, May, August and November (at 08:00:00 and 10:00:00)  
$dateTimeObject = $generator->nextInEveryQuart([2], [1, 15], [new \DateTime('10:00:00'), new \DateTime('08:00:00')]);

Arguments :

  • array $monthOffsets Array of month offsets in quart (integers). (1 = January, April, July, October. 2 = February, May, August, November. 3 = March, June, September, December). Default: Only 1 (January, April, July, October)
  • array $daysInMonth Array of days in month (integers). (1=>31). Default: Only 1 (1st)
  • array $times Times (Array of DateTime or DateTimeImmutable objects). Default: only 00:00:00

Frequency "every half year"

//Every 1st and 15th February and August (at 08:00:00 and 10:00:00)  
$dateTimeObject = $generator->nextInEveryHalfYear([2], [1, 15], [new \DateTime('10:00:00'), new \DateTime('08:00:00')]);
  • array $monthOffsets Array of month offsets in half year (integers). 1 = January, July. 2 = February, August. 3 = March, September. 4 = April, October. 5 = May , November. 6 = June, December). Default: Only 1 (January, July)
  • array $daysInMonth Array of days in month (integers). (1=>31). Default: Only 1 (1st)
  • array $times Times (Array of DateTime or DateTimeImmutable objects). Default: only 00:00:00

Frequency "every year"

//Every 1st and 15th January (at 08:00:00 and 10:00:00)  
$dateTimeObject = $generator->nextInEveryYear([1], [1, 15], [new \DateTime('10:00:00'), new \DateTime('08:00:00')]);
  • array $monthOffsets Array of month offsets in year (integers). (1 = January => 12 => December). Default: Only 1 (January)
  • array $daysInMonth Array of days in month (integers). (1=>31). Default: Only 1 (1st)
  • array $times Times (Array of DateTime or DateTimeImmutable objects). Default: only 00:00:00

Generate DateTimeImmutable objects

The generator generates by default DateTime objects.

The generator can generate DateTimeImmutable objets with generateDateTimeImmutable method:

use Ecommit\FrequencyGenerator\FrequencyGenerator;

$generator = new FrequencyGenerator();

$date = $generator->nextInEveryDay([new \DateTime('10:00:00'), new \DateTime('08:00:00')]);
echo get_class($date); //This example will output "DateTime"

$generator->generateDateTimeImmutable(true);
$date = $generator->nextInEveryDay([new \DateTime('10:00:00'), new \DateTime('08:00:00')]);
echo get_class($date); //This example will output "DateTimeImmutable"

$generator->generateDateTimeImmutable(false);
$date = $generator->nextInEveryDay([new \DateTime('10:00:00'), new \DateTime('08:00:00')]);
echo get_class($date); //This example will output "DateTime"

License

This librairy is under the MIT license. See the complete license in LICENSE file.

统计信息

  • 总下载量: 6.23k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 7
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 2
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2016-08-21

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固