How to calculate amount of days in each quarter

2019-09-15 11:53发布

I would like to know how properly get amount of days in each year quarter. With take in to the account leap year.

For example:

  • 1 quarter : 90 (or 91 Leap year)
  • 2 quarter : 91 -current quarter
  • 3 quarter : 92
  • 4 quarter : 92

From the docs it is possible to understand that we should divide year 12 into 4 parts. Then get amount of day of each quarter like 3 * (amount of days in 3 months). But how it is could be done in more sophisticated way and without of the hardcode.

标签: swift time
2条回答
闹够了就滚
2楼-- · 2019-09-15 12:03

You can use DateFormatter dateFormat "q" and convert it to integer.

extension Formatter {
    static let quarter: DateFormatter = {
        let formatter = DateFormatter()
        formatter.calendar = Calendar(identifier: .iso8601)
        formatter.locale = Locale(identifier: "en_US_POSIX")
        formatter.dateFormat = "q"
        return formatter
    }()
}

extension Calendar {
    static let iso8601 = Calendar(identifier: .iso8601)
}

extension Date {
    var year: Int { return Calendar.iso8601.dateComponents([.year], from: self).year ?? 0 }
    var quarter: Int { return Int(Formatter.quarter.string(from: self))! }

    var firstDayOfYear: Date { return DateComponents(calendar: .iso8601, year: year, month: 1, day: 1).date!}
    var firstDayOfNextYear: Date { return DateComponents(calendar: .iso8601, year: year.advanced(by: 1), month: 1, day: 1).date! }

    var quarters: (q1: Int, q2: Int, q3: Int, q4: Int) {
        var date = firstDayOfYear
        var q1 = 0, q2 = 0, q3 = 0, q4 = 0
        while date < firstDayOfNextYear {
            switch date.quarter {
            case 1: q1 += 1
            case 2: q2 += 1
            case 3: q3 += 1
            case 4: q4 += 1
            default:
                break
            }
            date = Calendar.iso8601.date(byAdding: DateComponents(day: 1), to: date)!
        }
        return (q1: q1, q2: q2, q3: q3, q4: q4)
    }
}

Playground testing:

Date().quarter                  // 2
Date().firstDayOfYear.quarter   // 1

Date().quarters   // q1 90, q2 91, q3 92, q4 92)
查看更多
Root(大扎)
3楼-- · 2019-09-15 12:10

You should use NSCalendar object in order to calculate number of days for each quarter.

For example: for first quarter: 01 Jan to 01 April

let df = DateFormatter()
df.dateFormat = "yyyy-MM-dd"

let firstDate = df.date(from: "2017-01-01")!
let secondDate = df.date(from: "2017-04-01")!

let calendar = Calendar(identifier: .gregorian)
let dateComponents = calendar.dateComponents([Calendar.Component.day], from: firstDate, to: secondDate)

print("number of day of Q1: \(dateComponents.day)")
查看更多
登录 后发表回答