亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何優化多個 google-api-calendars freeBussy 查詢

如何優化多個 google-api-calendars freeBussy 查詢

Go
繁花不似錦 2022-06-27 17:25:14
我正在開發一個 Go REST API 項目,在該項目中我收到一個具有不同間隔的 POST 請求。這反映了一家商店的營業時間,這里是一個例子:{    ...    "intervals": [        {            "day": "1600347600",            "starthours": "800",            "endhours": "1200"        },        {            "day": "1600434000",            "starthours": "1300",            "endhours": "1700"        },        {            "day": "1600520400",            "starthours": "800",            "endhours": "1200"        },        ...    ]}我向 Google 發出請求的代碼如下:    // Some code to get the token        //We treat every interval obj sent on the params    if len(sc.Intervals) > 0 {        for _, i := range sc.Intervals {            //This is a necessary step as the format of the dates that the client gives me            //are             dStart, dEnd, err := getDateStartAndEnd(i)            if err != nil {                log.Error(err)                return responseInterval, err            }            //0. build search criteria            var query = events.SearchCriteria{                Email:          sc.Owner.Email,                FreeBussyQuery: calendar.FreeBusyRequest{                    TimeMin: dStart.Format(time.RFC3339),                    TimeMax: dEnd.Format(time.RFC3339),                },            }            isFree, err := calendarService.Freebusy.Query(setCalendarId(query)).Do()            if err != nil {                log.Error(err)            }            //In this function I do two things, get all the "slots" of 15m availables            //in an given interval, then compare them to the bussy answer of Google            //to fill a new slice with free "slots"            freeIntervales := findFreeIntervales(isFree,dStart,dEnd)            responseInterval.Interval = append(responseInterval.Interval,freeIntervales)        }    }雖然我承認這可能不是最有效的算法,但我的主要問題是,假設有 8 個間隔,我的請求需要 5 秒才能執行。有沒有更好的方法來查詢谷歌日歷?或者我應該在這里修改我的邏輯嗎?我曾想過只用多個間隔進行一次查詢來檢查谷歌日歷,但這似乎是不可能的。一個可能的解決方案是讓我采取最早和最晚的時間并提出獨特的要求。這會是一個可行的解決方案嗎?
查看完整描述

1 回答

?
嗶嗶one

TA貢獻1854條經驗 獲得超8個贊

最后,我意識到為什么我只能打五個電話給 Google?這大大加快了速度。以前需要 5 - 6 秒,現在需要 900 毫秒 - 1400 毫秒。


我只是取了第一個間隔的第一個日期和最后一個間隔的最后一個日期,并要求谷歌給我該范圍內的所有忙碌細節。


    if len(sc.Intervals) > 0 {


    dStartResult, _, err:= getDateStartAndEnd(sc.Intervals[0])

    if err != nil {

        log.Error(err)

    }

    _, dEndResultLast, err:= getDateStartAndEnd(sc.Intervals[len(sc.Intervals)-1])

    if err != nil {

        log.Error(err)

    }


    //0. build search criteria

    var query = events.SearchCriteria{

        Email:          sc.Owner.Email,

        FreeBussyQuery: calendar.FreeBusyRequest{

            TimeMin: dStartResult.Format(time.RFC3339),

            TimeMax: dEndResultLast.Format(time.RFC3339),

        },

    }

    isFree, err := calendarService.Freebusy.Query(setCalendarId(query)).Do()

    if err != nil {

        log.Error(err)

    }


    for _, i := range sc.Intervals {

        ....

        //Do some magic to get the free intervals


查看完整回答
反對 回復 2022-06-27
  • 1 回答
  • 0 關注
  • 137 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號