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


Python parsedatetime.Calendar方法代碼示例

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


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

示例1: _parse_date

# 需要導入模塊: import parsedatetime [as 別名]
# 或者: from parsedatetime import Calendar [as 別名]
def _parse_date(date_str, tz):
        try:
            dt = datetime.strptime(date_str.strip(), "%m-%d-%Y %I:%M %p")
            return dt.replace(tzinfo=tz).astimezone(UTC)

        except ValueError:
            # in case like "Yesterday 3:30 PM" or dates like that.

            # calculates based on sourceTime. tz is 2p2 forum timezone
            source = datetime.now(UTC).astimezone(tz)
            dt, pt = parsedatetime.Calendar().parseDT(
                date_str, tzinfo=tz, sourceTime=source
            )

            # parsed as a C{datetime}, means that parsing was successful
            if pt == 3:
                return dt.astimezone(UTC)
            raise ValueError(f"Could not parse date: {date_str}") 
開發者ID:pokerregion,項目名稱:poker,代碼行數:20,代碼來源:twoplustwo.py

示例2: get_timestamp

# 需要導入模塊: import parsedatetime [as 別名]
# 或者: from parsedatetime import Calendar [as 別名]
def get_timestamp(value):
    '''Return timestamp from a human readable date'''

    if not value:
        return

    # If already a timestamp return a float
    try:
        timestamp = float(value)
        return timestamp
    except ValueError:
        pass

    # Convert human readable string to timestamp
    cal = pdt.Calendar()
    timestamp = (cal.parseDT(value)[0]).timestamp()
    return timestamp 
開發者ID:linkedin,項目名稱:fossor,代碼行數:19,代碼來源:cli.py

示例3: getTimeVec

# 需要導入模塊: import parsedatetime [as 別名]
# 或者: from parsedatetime import Calendar [as 別名]
def getTimeVec(inStr):
	cal = parsedatetime.Calendar()
	[T, worked] = cal.parse(fixStr(inStr))

	T  = [item for item in T]

	#if worked == 0:
	#	print "PARSE FAILED"

	#time.struct_time(tm_year=2015, tm_mon=7, tm_mday=3, tm_hour=4, tm_min=6, tm_sec=36, tm_wday=4, tm_yday=184, tm_isdst=-1)

	Year = T[0]
	Month = T[1]
	DayOfMonth = T[2]
	Hour24 = T[3]
	Minute = T[4]
	Second = T[5]
	Weekday = T[6]
	DayOfYear = T[7]

	#NOW = cal.parse("now")

	return {"year":Year, "month":Month, "day":DayOfMonth, "hour":Hour24, "minute":Minute, "second":Second, "worked":worked!=0} 
開發者ID:tannerbohn,項目名稱:MindMap,代碼行數:25,代碼來源:utils.py

示例4: date_time_from_str

# 需要導入模塊: import parsedatetime [as 別名]
# 或者: from parsedatetime import Calendar [as 別名]
def date_time_from_str(datetime_str):
    """Parse a humanly readable datetime.

    Args:
      datetime_str: str, humanly readable date time.

    Returns:
      datetime, correctponding datetime object.
    """
    cal = parsedatetime.Calendar()
    parsed_result, date_type = cal.parse(datetime_str)
    parsed_datetime = None

    if date_type == 3:
        # parsed_result is a datetime
        parsed_datetime = parsed_result
    elif date_type in (1, 2):
        # parsed_result is struct_time
        parsed_datetime = datetime.datetime(*parsed_result[:6])
    else:
        # Failed to parse
        raise ValueError("Could not parse date/time string: " + datetime_str)
    return parsed_datetime 
開發者ID:criteo,項目名稱:biggraphite,代碼行數:25,代碼來源:command.py

示例5: parse_time_string

# 需要導入模塊: import parsedatetime [as 別名]
# 或者: from parsedatetime import Calendar [as 別名]
def parse_time_string(time_str, tz='US/Pacific'):
    """ Convert a date or time string into an arrow object in UTC

    :param time_str: the string to convert
    :param tz: what timezone to interpret the time_str as *if no tz is specified*
    :returns: an arrow object representing the time_str in UTC
    :raises ValueError: if the time_str could not be parsed
    """

    # parsedatetime doesn't handle ISO-8601 time strings (YYYY-MM-DDThh:mm:ss+zz) so
    # try to parse it with arrow first and then use parsedatetime as a fallback (grumble)
    t = None
    try:
        t = arrow.get(time_str)
        # If the input string didn't specify a timezone, fill in the default
        if len(time_str.split('+')) == 1:
            t = t.replace(tzinfo=tz)
    except arrow.parser.ParserError:
        cal = parsedatetime.Calendar()
        parse_result = cal.parse(time_str)
        if parse_result[1] == 0:
            raise ValueError('Could not understand time {time}'.format(time=time_str))
        t = arrow.get(parse_result[0]).replace(tzinfo=tz)
    return t.to('utc') 
開發者ID:Yelp,項目名稱:clusterman,代碼行數:26,代碼來源:util.py

示例6: parse_human_timedelta

# 需要導入模塊: import parsedatetime [as 別名]
# 或者: from parsedatetime import Calendar [as 別名]
def parse_human_timedelta(human_readable: Optional[str]) -> timedelta:
    """
    Returns ``datetime.datetime`` from natural language time deltas

    >>> parse_human_datetime('now') <= datetime.now()
    True
    """
    cal = parsedatetime.Calendar()
    dttm = dttm_from_timetuple(datetime.now().timetuple())
    date_ = cal.parse(human_readable or "", dttm)[0]
    date_ = datetime(
        date_.tm_year,
        date_.tm_mon,
        date_.tm_mday,
        date_.tm_hour,
        date_.tm_min,
        date_.tm_sec,
    )
    return date_ - dttm 
開發者ID:apache,項目名稱:incubator-superset,代碼行數:21,代碼來源:core.py

示例7: interval_type

# 需要導入模塊: import parsedatetime [as 別名]
# 或者: from parsedatetime import Calendar [as 別名]
def interval_type(string):
    """Type parser for argparse. Argument must be a valid interval format.
    Supports any format supported by `parsedatetime`, including:
        * "30sec" (every 30 seconds)
        * "5 minutes" (every 5 minutes)
        * "1h" (every hour)
        * "2 hours 1 min and 30 seconds"
    """
    m = datetime.datetime.min
    cal = parsedatetime.Calendar()
    interval = cal.parseDT(string, sourceTime=m)[0] - m
    if interval == m:
        error = "Invalid interval format: {}".format(string)
        raise argparse.ArgumentTypeError(error)

    return interval 
開發者ID:amietn,項目名稱:vcsi,代碼行數:18,代碼來源:vcsi.py

示例8: parseHumanReadableDate

# 需要導入模塊: import parsedatetime [as 別名]
# 或者: from parsedatetime import Calendar [as 別名]
def parseHumanReadableDate(self,datestr):
		"""Parses a human-readable date string to python's date object"""
		cal = pdt.Calendar()
		now = datetime.datetime.now()
		return cal.parseDT(datestr, now)[0].date()


	#------------------------ Fitbit to Google Fit convertors ---------------------------- 
開發者ID:praveendath92,項目名稱:fitbit-googlefit,代碼行數:10,代碼來源:convertors.py

示例9: action

# 需要導入模塊: import parsedatetime [as 別名]
# 或者: from parsedatetime import Calendar [as 別名]
def action(self):
        self._logger.info('Start viewing the log events...')

        def _exit(signum, frame):
            self._logger.info('Exit by code {} ...'.format(signum))
            self._exit = True

        signal.signal(signal.SIGTERM, _exit)
        signal.signal(signal.SIGINT, _exit)

        start = time.time()
        if self._start is not None:
            time_struct, _ = Calendar().parse(self._start)
            start = mktime(time_struct)

        start = int(start * 1000)

        client = self.get_logs_client()
        function = self._config.get_function_name()
        event_ids = {}

        while self._exit is False:
            events = client.get_log_events(function, start, self._filter)

            for e in events:
                if e['eventId'] not in event_ids:
                    event_ids[e['eventId']] = None
                    print(e['message'])

                    if e['timestamp'] > start:
                        start = e['timestamp']
                        event_ids = {}

            if not self._follow:
                break

            time.sleep(self._interval) 
開發者ID:marcy-terui,項目名稱:lamvery,代碼行數:39,代碼來源:logs.py

示例10: _parse_datetime

# 需要導入模塊: import parsedatetime [as 別名]
# 或者: from parsedatetime import Calendar [as 別名]
def _parse_datetime(string, timezone):
    res, code = parsedatetime.Calendar().parseDT(
        string, sourceTime=time.localtime(),
        tzinfo=pytz.timezone(timezone),
    )

    if code == 0:
        raise ValueError("Unable to parse %s as a timestamp" % string)

    return arrow.Arrow.fromdatetime(res) 
開發者ID:google,項目名稱:rekall,代碼行數:12,代碼來源:protocols.py

示例11: __init__

# 需要導入模塊: import parsedatetime [as 別名]
# 或者: from parsedatetime import Calendar [as 別名]
def __init__(self, filename):
		# load timeline data
		s = ''
		with open(filename) as f:
			s = f.read()
		self.data = json.loads(s)
		assert 'width' in self.data, 'width property must be set'
		assert 'start' in self.data, 'start property must be set'
		assert 'end' in self.data, 'end property must be set'
		# create drawing
		self.width = self.data['width']
		self.drawing = svgwrite.Drawing()
		self.drawing['width'] = self.width
		self.g_axis = self.drawing.g()		
		# figure out timeline boundaries
		self.cal = parsedatetime.Calendar()
		self.start_date = self.datetime_from_string(self.data['start'])
		self.end_date = self.datetime_from_string(self.data['end'])
		delta = self.end_date[0] - self.start_date[0]
		padding = datetime.timedelta(seconds=0.1*delta.total_seconds())
		self.date0 = self.start_date[0] - padding
		self.date1 = self.end_date[0] + padding
		self.total_secs = (self.date1 - self.date0).total_seconds()	
		# set up some params
		self.callout_size = (10, 15, 10) # width, height, increment
		self.text_fudge = (3, 1.5)
		self.tick_format = self.data.get('tick_format', None)
		self.markers = {}
		# initialize Tk so that font metrics will work
		self.tk_root = Tkinter.Tk()
		self.fonts = {}
		# max_label_height stores the max height of all axis labels
		# and is used in the final height computation in build(self)
		self.max_label_height = 0 
開發者ID:jasonreisman,項目名稱:Timeline,代碼行數:36,代碼來源:make_timeline.py

示例12: date_from_string

# 需要導入模塊: import parsedatetime [as 別名]
# 或者: from parsedatetime import Calendar [as 別名]
def date_from_string(timeString):
    cal = pdt.Calendar()
    now = datetime.now()
    result = str(cal.parseDT(timeString.strip(), now)[0])
    return result 
開發者ID:alfredfrancis,項目名稱:ai-chatbot-framework,代碼行數:7,代碼來源:utils.py

示例13: parse_time_interval_seconds

# 需要導入模塊: import parsedatetime [as 別名]
# 或者: from parsedatetime import Calendar [as 別名]
def parse_time_interval_seconds(time_str):
    """ Convert a given time interval (e.g. '5m') into the number of seconds in that interval

    :param time_str: the string to parse
    :returns: the number of seconds in the interval
    :raises ValueError: if the string could not be parsed
    """
    cal = parsedatetime.Calendar()
    parse_result = cal.parseDT(time_str, sourceTime=datetime.min)
    if parse_result[1] == 0:
        raise ValueError('Could not understand time {time}'.format(time=time_str))
    return (parse_result[0] - datetime.min).total_seconds() 
開發者ID:Yelp,項目名稱:clusterman,代碼行數:14,代碼來源:util.py

示例14: parse_human_datetime

# 需要導入模塊: import parsedatetime [as 別名]
# 或者: from parsedatetime import Calendar [as 別名]
def parse_human_datetime(human_readable: str) -> datetime:
    """
    Returns ``datetime.datetime`` from human readable strings

    >>> from datetime import date, timedelta
    >>> from dateutil.relativedelta import relativedelta
    >>> parse_human_datetime('2015-04-03')
    datetime.datetime(2015, 4, 3, 0, 0)
    >>> parse_human_datetime('2/3/1969')
    datetime.datetime(1969, 2, 3, 0, 0)
    >>> parse_human_datetime('now') <= datetime.now()
    True
    >>> parse_human_datetime('yesterday') <= datetime.now()
    True
    >>> date.today() - timedelta(1) == parse_human_datetime('yesterday').date()
    True
    >>> year_ago_1 = parse_human_datetime('one year ago').date()
    >>> year_ago_2 = (datetime.now() - relativedelta(years=1) ).date()
    >>> year_ago_1 == year_ago_2
    True
    """
    try:
        dttm = parse(human_readable)
    except Exception:  # pylint: disable=broad-except
        try:
            cal = parsedatetime.Calendar()
            parsed_dttm, parsed_flags = cal.parseDT(human_readable)
            # when time is not extracted, we 'reset to midnight'
            if parsed_flags & 2 == 0:
                parsed_dttm = parsed_dttm.replace(hour=0, minute=0, second=0)
            dttm = dttm_from_timetuple(parsed_dttm.utctimetuple())
        except Exception as ex:
            logger.exception(ex)
            raise ValueError("Couldn't parse date string [{}]".format(human_readable))
    return dttm 
開發者ID:apache,項目名稱:incubator-superset,代碼行數:37,代碼來源:core.py

示例15: extractSeriesReleases

# 需要導入模塊: import parsedatetime [as 別名]
# 或者: from parsedatetime import Calendar [as 別名]
def extractSeriesReleases(self, seriesPageUrl, soup):
		chapter_divs = soup.find_all("a", class_='chapter-link')
		retval = []

		for linka in chapter_divs:
			state   = linka['data-preprocessor-state']
			vol     = linka['data-preprocessor-vol']
			chp     = linka['data-preprocessor-chp']
			name    = linka['data-preprocessor-name']
			index   = linka['data-preprocessor-index']
			title   = linka['data-preprocessor-title']
			reldate = linka['data-preprocessor-reldate']
			href    = linka['href']



			itemDate, status = parsedatetime.Calendar().parse(reldate)

			if status < 1:
				continue

			reldate = time.mktime(itemDate)

			relurl = common.util.urlFuncs.rebaseUrl(linka['href'] + "/", seriesPageUrl)


			print([vol, chp, state, linka])

			raw_item = {}
			raw_item['srcname']   = "Qidian"
			raw_item['published'] = float(reldate)
			raw_item['linkUrl']   = relurl

			if state == '0':
				raw_msg = msgpackers.buildReleaseMessageWithType(raw_item, title, None, index, None, tl_type='translated', prefixMatch=True)
				retval.append(msgpackers.serialize_message(raw_msg))
			elif state == "2":
				raw_msg = msgpackers.buildReleaseDeleteMessageWithType(raw_item, title, None, index, None, tl_type='translated', prefixMatch=True)
				retval.append(msgpackers.serialize_message(raw_msg))
			else:
				print("Unknown state:", state)

		# Do not add series without 3 chapters.
		if len(retval) < 3:
			self.log.info("Less then three chapters!")
			return []

		# if not retval:
		# 	self.log.info("Retval empty?!")
		# 	return []

		# return []

		return retval 
開發者ID:fake-name,項目名稱:ReadableWebProxy,代碼行數:56,代碼來源:QidianSeriesPageFilter.py


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