當前位置: 首頁>>代碼示例>>Python>>正文


Python astral.Location方法代碼示例

本文整理匯總了Python中astral.Location方法的典型用法代碼示例。如果您正苦於以下問題:Python astral.Location方法的具體用法?Python astral.Location怎麽用?Python astral.Location使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在astral的用法示例。


在下文中一共展示了astral.Location方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: calculate_sunrise

# 需要導入模塊: import astral [as 別名]
# 或者: from astral import Location [as 別名]
def calculate_sunrise(year_to_simulate, longitude, latitude):
    """
    Calculate the hour of sunrise for a given year, longitude and latitude. Returns an array
    of hours.
    """

    # get the time zone name
    tf = TimezoneFinder()
    time_zone = tf.timezone_at(lng=longitude, lat=latitude)

    # define the city_name
    location = Location()
    location.name = 'name'
    location.region = 'region'
    location.latitude = latitude
    location.longitude = longitude
    location.timezone = time_zone
    location.elevation = 0

    sunrise = []
    for day in range(1, 366):  # Calculated according to NOAA website
        dt = datetime.datetime(year_to_simulate, 1, 1) + datetime.timedelta(day - 1)
        dt = pytz.timezone(time_zone).localize(dt)
        sun = location.sun(dt)
        sunrise.append(sun['sunrise'].hour)
    print('complete calculating sunrise')
    return sunrise 
開發者ID:architecture-building-systems,項目名稱:CityEnergyAnalyst,代碼行數:29,代碼來源:radiation.py

示例2: get_sunrise_sunset

# 需要導入模塊: import astral [as 別名]
# 或者: from astral import Location [as 別名]
def get_sunrise_sunset(self, date = None):
        if self.data['sunrise_time'] is not None and self.data['sunset_time'] is not None:
            if date is None:
                date = dt_now(self.data['timezone'])
            sunrise = date.replace(hour=int(self.data['sunrise_time'].strftime("%H")), minute=int(self.data['sunrise_time'].strftime("%M")), second=int(self.data['sunrise_time'].strftime("%S")), microsecond=int(self.data['sunrise_time'].strftime("%f")))
            sunset = date.replace(hour=int(self.data['sunset_time'].strftime("%H")), minute=int(self.data['sunset_time'].strftime("%M")), second=int(self.data['sunset_time'].strftime("%S")), microsecond=int(self.data['sunset_time'].strftime("%f")))
            solar_noon = sunrise + (sunset - sunrise)/2
            solar_midnight = sunset + ((sunrise + timedelta(days=1)) - sunset)/2
        else:
            import astral
            location = astral.Location()
            location.name = 'name'
            location.region = 'region'
            location.latitude = self.data['latitude']
            location.longitude = self.data['longitude']
            location.elevation = self.data['elevation']
            _LOGGER.debug("Astral location: " + str(location))
            if self.data['sunrise_time'] is not None:
                if date is None:
                    date = dt_now(self.data['timezone'])
                sunrise = date.replace(hour=int(self.data['sunrise_time'].strftime("%H")), minute=int(self.data['sunrise_time'].strftime("%M")), second=int(self.data['sunrise_time'].strftime("%S")), microsecond=int(self.data['sunrise_time'].strftime("%f")))
            else:
                sunrise = location.sunrise(date)
            if self.data['sunset_time'] is not None:
                if date is None:
                    date = dt_now(self.data['timezone'])
                sunset = date.replace(hour=int(self.data['sunset_time'].strftime("%H")), minute=int(self.data['sunset_time'].strftime("%M")), second=int(self.data['sunset_time'].strftime("%S")), microsecond=int(self.data['sunset_time'].strftime("%f")))
            else:
                sunset = location.sunset(date)
            solar_noon = location.solar_noon(date)
            solar_midnight = location.solar_midnight(date)
        if self.data['sunrise_offset'] is not None:
            sunrise = sunrise + self.data['sunrise_offset']
        if self.data['sunset_offset'] is not None:
            sunset = sunset + self.data['sunset_offset']
        return {
            SUN_EVENT_SUNRISE: sunrise.astimezone(self.data['timezone']),
            SUN_EVENT_SUNSET: sunset.astimezone(self.data['timezone']),
            'solar_noon': solar_noon.astimezone(self.data['timezone']),
            'solar_midnight': solar_midnight.astimezone(self.data['timezone'])
        } 
開發者ID:claytonjn,項目名稱:hass-circadian_lighting,代碼行數:43,代碼來源:__init__.py

示例3: make_sky

# 需要導入模塊: import astral [as 別名]
# 或者: from astral import Location [as 別名]
def make_sky(self):
        self.sky = ""

        self.dt = pytz.timezone('America/New_York').localize(datetime.now())
        self.loc = astral.Location(("New York","New York", 40.7527, -73.9772,"America/New_York","0"))

        if self.dt >= self.loc.sunrise(self.dt.date()) and self.dt <= self.loc.sunset(self.dt.date()):
            self.make_daysky()
            self.get_weather()
        else:
            self.make_nightsky()
       
        return self.sky 
開發者ID:thisisparker,項目名稱:choochoobot,代碼行數:15,代碼來源:choochoogen.py

示例4: main

# 需要導入模塊: import astral [as 別名]
# 或者: from astral import Location [as 別名]
def main(us_se):
    if 'location' not in us_se:
        logger.error('Invalid config file')
        return

    if us_se['location']['auto_enabled']:
        loc = get_loc_from_ip()
        if loc:
            loc = loc.json()
        else:
            logger.error('Couldn\'t connect to ipinfo, giving up')
            return

        loc['latitude'], loc['longitude'] = (float(x) for x in loc['loc'].strip().split(','))
        loc['time_zone'] = tzlocal.get_localzone().zone

    else:
        for k, v in us_se['location']['manual'].items():
            try:
                val = v.strip()
            except AttributeError:
                pass
            else:
                if not val:
                    logger.error('Auto location is not enabled and some manual values are missing')
                    return
        loc = us_se['location']['manual']

    try:
        location = Location()
        location.name = loc['city']
        location.region = loc['region']
        location.latitude = loc['latitude']
        location.longitude = loc['longitude']
        location.timezone = loc['time_zone']
    except ValueError as e:
        logger.error(str(e))
        return

    sunrise = location.sun()['sunrise'].replace(second=0) + timedelta(minutes=us_se['offset']['sunrise'])
    sunset = location.sun()['sunset'].replace(second=0) + timedelta(minutes=us_se['offset']['sunset'])

    #   Convert to UTC for storage
    return sunrise.astimezone(pytz.utc), sunset.astimezone(pytz.utc)


#   This should only be called when running through systemd 
開發者ID:C2N14,項目名稱:AutomaThemely,代碼行數:49,代碼來源:updsuntimes.py


注:本文中的astral.Location方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。