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


Python Formatter.data方法代碼示例

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


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

示例1: getHealthNews

# 需要導入模塊: import Formatter [as 別名]
# 或者: from Formatter import data [as 別名]
def getHealthNews(lan='en',format='json'):
	returnData = MutableString()
	returnData = ''
	if (lan == 'es'):
		dom = minidom.parse(urllib.urlopen(AppConfig.medlinePlusHealthNewsSpanishURL))
	else:
		dom = minidom.parse(urllib.urlopen(AppConfig.medlinePlusHealthNewsEnglishURL))
	rssTitle = MutableString()
	rssDescription = MutableString()
	rssURL = MutableString()
	for node in dom.getElementsByTagName('item'):
		for item_node in node.childNodes:
			rssTitle = ''
			rssDescription = ''
			rssURL = ''
			#item title
			if (item_node.nodeName == "title"):
				for text_node in item_node.childNodes:
					if (text_node.nodeType == node.TEXT_NODE):
						rssTitle += text_node.nodeValue
			#description
			if (item_node.nodeName == "description"):
				for text_node in item_node.childNodes:
					rssDescription += text_node.nodeValue
			#link to URL
			if (item_node.nodeName == "link"):
				for text_node in item_node.childNodes:
					rssURL += text_node.nodeValue
			
			if (format == 'json'):
				startTag = '{'
				endTag = '},'
				
				#cleanup
				#rssTitle = re.sub("\"", "'", rssTitle)
				rssTitle = re.sub("\n", "", rssTitle)
				rssTitle = re.sub("\"", "\\\"", rssTitle)
				rssDescription = re.sub("\"", "\\\"", rssDescription)
				rssDescription = re.sub("\n", "", rssDescription)
				rssDescription = re.sub("\t", " ", rssDescription)
				rssDescription = re.sub("\r", "", rssDescription)
				
				if (len(rssDescription) > 0):
					rssDescription = Formatter.data(format, 'description', escape(rssDescription))[:-1]
			else:
				startTag = '<record>'
				endTag = '</record>'		
				if (len(rssDescription) > 0):
					rssDescription = Formatter.data(format, 'description', escape(rssDescription))								
			
			if (len(rssTitle) > 0):
				returnData += startTag + Formatter.data(format, 'title', rssTitle)
				
			if (len(rssURL) > 0):
				returnData += Formatter.data(format, 'url', rssURL) 
			
			if (len(rssDescription) > 0 ):
				returnData += rssDescription + endTag
	
	return returnData
開發者ID:,項目名稱:,代碼行數:62,代碼來源:

示例2: getDiagnosisICD9Data

# 需要導入模塊: import Formatter [as 別名]
# 或者: from Formatter import data [as 別名]
	def getDiagnosisICD9Data(self,xml,format):
		if (xml):
			documentElms = xml.getElementsByTagName('entry')
			if (documentElms):
				#grab two highest ranked content
				content1 = ''
				content2 = ''
				
				contentNode1 = documentElms[0]
				content1 = APIUtils.parseHealthDiagnosisICD9Content(format,contentNode1)
				
				if (len(documentElms) > 0):
					contentNode2 = documentElms[1]
					content2 = APIUtils.parseHealthDiagnosisICD9Content(format,contentNode2)
				
				returnData = "%s%s" % (content1, content2)
				if (format == 'json'):
					return returnData[:-1]
				else:
					return returnData		
			else:
				logging.error('unable to retrieve diagnosis content')
				return Formatter.data(format, 'error', 'No results')
		else:
			logging.error('unable to retrieve diagnosis content')
			return Formatter.data(format, 'error', 'Unable to retrieve content from provider')
開發者ID:,項目名稱:,代碼行數:28,代碼來源:

示例3: get

# 需要導入模塊: import Formatter [as 別名]
# 或者: from Formatter import data [as 別名]
	def get(self,zip=None,format='json'):
		#set content-type
		self.response.headers['Content-Type'] = Formatter.contentType(format)
		
		#validate zip
		if (not zip or zip == ''):
			self.response.out.write(Formatter.error(format, 'invalid zipcode'))
			return
	
		#get lat/lon from zipcode
		urlStr = 'http://maps.google.com/maps/geo?q=%s&output=json&sensor=true&key=%s' % (zip,AppConfig.googleMapsAPIKey)
		jsonData = UtilLib.reverseGeo(urlStr)	
		#lets see if have jsonData from reverse geocoding call
		if (jsonData):
			lon = jsonData['Placemark'][0]['Point']['coordinates'][0]
			lat = jsonData['Placemark'][0]['Point']['coordinates'][1]
			logging.debug("GPS Coordinates: %s,%s" % (lat,lon))
			gb = geobox2.Geobox(lat, lon)
			#scope 100 miles
			box = gb.search_geobox(100)
			query = HospitalInfo.all().filter("geoboxes IN", [box])
			#get 100 records
			results = query.fetch(100)
			db_recs = {}
			for result in results:
				distance = UtilLib.getEarthDistance(lat, lon, result.location.lat, result.location.lon)
				if (distance and distance > 0):
					db_recs[distance] = result
			
			returnData = MutableString()
			returnData = ''
					
			#output this badboy
			if (db_recs and len(db_recs) > 0):
				for key in sorted(db_recs.iterkeys()):
					p = db_recs[key]
					if (format == 'json'):
						startTag = '{'
						endTag = '},'
						distance = Formatter.data(format, 'distance', '%s %s' % (str(math.ceil(key)), "mi"))[:-1]#'%.2g %s' % (key, "mi"))[:-1]
					else:
						startTag = '<record>'
						endTag = '</record>'
						distance = Formatter.data(format, 'distance', '%s %s' % (str(math.ceil(key)), "mi"))
					#build the string	
					returnData = "%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s" % (returnData,startTag,
																Formatter.data(format, 'hospital_id', p.hospital_id),
																Formatter.data(format, 'name', p.name.replace('&', '&amp;')),
																Formatter.data(format, 'address', p.address.replace('&', '&amp;')),
																Formatter.data(format, 'city', p.city),
																Formatter.data(format, 'state', p.state),
																Formatter.data(format, 'zip_code', p.zip_code),
																Formatter.data(format, 'county', p.county.replace('&', '&amp;')),
																Formatter.data(format, 'phone', p.phone),
																Formatter.data(format, 'hospital_type', p.hospital_type.replace('&', '&amp;')),
																Formatter.data(format, 'hospital_owner', p.hospital_owner.replace('&', '&amp;')),
																Formatter.data(format, 'emergency_service', p.emergency_service),
																Formatter.data(format, 'geo_location', p.location),
																distance,
																endTag
																)
																 
			
			#output to the browser
			self.response.out.write(Formatter.dataWrapper(format, returnData))
		else:
			self.response.out.write(Formatter.error(format, 'Unable to perform reverse geoencoding'))
			return
開發者ID:,項目名稱:,代碼行數:70,代碼來源:

示例4: getHospitalData

# 需要導入模塊: import Formatter [as 別名]
# 或者: from Formatter import data [as 別名]
	def getHospitalData(self,lat,lon,format):
		#get hospital data
		gb = geobox2.Geobox(lat, lon)
		box = gb.search_geobox(100)
		query = HospitalInfo.all().filter("geoboxes IN", [box])
		results = query.fetch(100)
		db_recs = {}
		for result in results:
			distance = UtilLib.getEarthDistance(lat, lon, result.location.lat, result.location.lon)
			if (distance and distance > 0):
				db_recs[distance] = result
		
		returnData = MutableString()
		returnData = ''

		#output this badboy
		if (db_recs and len(db_recs) > 0):
			for key in sorted(db_recs.iterkeys()):
				p = db_recs[key]
				if (format == 'json'):
					startTag = '{'
					endTag = '},'
					distance = Formatter.data(format, 'distance', '%s %s' % (str(math.ceil(key)), "mi"))[:-1]#'%.2g %s' % (key, "mi"))[:-1]
				else:
					startTag = '<record>'
					endTag = '</record>'
					distance = Formatter.data(format, 'distance', '%s %s' % (str(math.ceil(key)), "mi"))
				#build the string	
				returnData = "%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s" % (returnData,startTag,
															Formatter.data(format, 'hospital_id', p.hospital_id),
															Formatter.data(format, 'name', p.name.replace('&', '&amp;')),
															Formatter.data(format, 'address', p.address.replace('&', '&amp;')),
															Formatter.data(format, 'city', p.city),
															Formatter.data(format, 'state', p.state),
															Formatter.data(format, 'zip_code', p.zip_code),
															Formatter.data(format, 'county', p.county.replace('&', '&amp;')),
															Formatter.data(format, 'phone', p.phone),
															Formatter.data(format, 'hospital_type', p.hospital_type.replace('&', '&amp;')),
															Formatter.data(format, 'hospital_owner', p.hospital_owner.replace('&', '&amp;')),
															Formatter.data(format, 'emergency_service', p.emergency_service),
															Formatter.data(format, 'geo_location', p.location),
															distance,
															endTag
															)
	
			if (format == 'json'):
				return returnData[:-1]
			else:
				return returnData
開發者ID:,項目名稱:,代碼行數:51,代碼來源:

示例5: getTopicData

# 需要導入模塊: import Formatter [as 別名]
# 或者: from Formatter import data [as 別名]
	def getTopicData(self,xml,format,lan='en'):
		if (xml):
			documentElms = xml.getElementsByTagName('document')
			if (documentElms):
				#grab two highest ranked content
				content1 = ''
				content2 = ''
				content3 = ''
				
				contentNode1 = documentElms[0]
				content1 = APIUtils.parseHealthTopicContent(format,contentNode1)
				
				if (len(documentElms) > 1):
					contentNode2 = documentElms[1]
					content2 = APIUtils.parseHealthTopicContent(format,contentNode2)
				
				if (len(documentElms) > 2):
					contentNode3 = documentElms[2]
					content3 = APIUtils.parseHealthTopicContent(format,contentNode3)
				
				returnData = "%s%s%s" % (content1, content2, content3)
				
				"""
				Giving up for now....major pain in the butt to translate entire XML or JSON document
				
				#fun stuff: lets see if we need to translate
				#because we have three content records it's better to 
				#translate the entire document (json or xml) instead of individual content summaries
				translatedData = ''
				if (lan != 'en'):
					#prep data
					#if JSON, replace record definition with non-translatable text
					if (format == 'json'):
						returnData = re.sub("\"", "X59X", returnData)
					else:
						#get rid of the tags. Google Translate doesn't seem to like them
						returnData = returnData#CharReplacementMap.translate_tags_from_xml_record(returnData)
					
					translatedData = self.translateData(lan,returnData.encode("utf-8"))
					self.out(translatedData)
					
									
				if (translatedData):
					#cheesy search&replace - need a quick solution to fix JSON
					if (format == 'json'):
						translatedData = re.sub("X59X","\"", translatedData)
						translatedData = re.sub("\n", "", translatedData)
						translatedData = re.sub("\r", "", translatedData)
						translatedData = re.sub("\t", "", translatedData)
					else:
						translatedData = translatedData#CharReplacementMap.translate_tags_to_xml_record(translatedData)
					
					return translatedData
				"""	
				if (format == 'json'):
					return returnData[:-1]
				else:
					return returnData
			else:
				logging.error('unable to retrieve health topic content')
				return Formatter.data(format, 'error', 'No results')
		else:
			logging.error('unable to retrieve health topic content')
			return Formatter.data(format, 'error', 'Unable to retrieve content from provider')
開發者ID:,項目名稱:,代碼行數:66,代碼來源:

示例6:

# 需要導入模塊: import Formatter [as 別名]
# 或者: from Formatter import data [as 別名]
		#get hospital data
		if (userLat and userLon):
			hospitalData = self.getHospitalData(userLat, userLon,format)
			if (hospitalData):
				returnData += Formatter.dataComplex(format, 'hospital-records', hospitalData)
		
		if (rpcClinicalTrials):
			clinicalTrialsData = ''
			try:
			    resultClinicalTrials = rpcClinicalTrials.get_result()
			    if (resultClinicalTrials and resultClinicalTrials.status_code == 200):
					if (resultClinicalTrials.content):
						clinicalTrialsData = self.getClinicalTrialsData(minidom.parseString(resultClinicalTrials.content), format)
					else:
						logging.error('unable to retrieve clinical trials content')
						clinicalTrialsData = Formatter.data(format, 'error', 'Unable to retrieve content from provider')
			except Exception,ex:
				logging.error('Errors getting clinical trials content: %s' % ex)
				clinicalTrialsData = Formatter.data(format, 'error', 'Error(s) retrieving content from provider: %s' % ex)
		
			#append to the overall dataset
			returnData += Formatter.dataComplex(format, 'clinicaltrials-records', clinicalTrialsData)
		
		#fetch ICD-9 diagnosis data
		if (rpcDiagnosis):
			diagnosisData = ''
			try:
			    resultDiagnosis = rpcDiagnosis.get_result()
			    if (resultDiagnosis and resultDiagnosis.status_code == 200):
					if (resultDiagnosis.content):
						diagnosisData = self.getDiagnosisICD9Data(minidom.parseString(resultDiagnosis.content), format)
開發者ID:,項目名稱:,代碼行數:33,代碼來源:

示例7: parseHealthTopicContent

# 需要導入模塊: import Formatter [as 別名]
# 或者: from Formatter import data [as 別名]
def parseHealthTopicContent(format,node):
	if (node):
		contentTitle = MutableString()
		contentAltTitle = MutableString()
		contentSummary = MutableString()
		contentTitle = ''
		contentAltTitle = ''
		contentSummary = ''
		
		for content_node in node.childNodes:
			#get title
			if (content_node and content_node.nodeName == 'content' and content_node.attributes['name'].value == "title"):
				for text_node in content_node.childNodes:
					contentTitle += CharReplacementMap.remove_html_tags(text_node.nodeValue)
			#get alt title
			"""if (content_node and content_node.nodeName == 'content' and content_node.attributes['name'].value == "altTitle"):
				for text_node in content_node.childNodes:
					contentAltTitle += remove_html_tags(text_node.nodeValue)
			"""
			#get content	
			if (content_node and content_node.nodeName == 'content' and content_node.attributes['name'].value == "FullSummary"):
				for text_node in content_node.childNodes:
					contentSummary += text_node.nodeValue
		
		#replace HTML tags with friendly tags (that will be replaced back to HTML later)
		#contentSummary = CharReplacementMap.translate_tags_from_html(contentSummary)
		#now strip HTML garbage
		#contentSummary = CharReplacementMap.remove_html_tags(contentSummary)
		
		returnData = MutableString()
		returnData = ''			
		if (format == 'json'):
			startTag = '{'
			endTag = '},'
			
			#cleanup
			contentTitle = re.sub("\n", "", contentTitle)
			contentTitle = re.sub("\"", "\\\"", contentTitle)
			contentAltTitle = re.sub("\n", "", contentAltTitle)
			contentAltTitle = re.sub("\r", "", contentAltTitle)
			contentAltTitle = re.sub("\"", "\\\"", contentAltTitle)
			contentSummary = re.sub("\"", "\\\"", contentSummary)
			contentSummary = re.sub("\n", "", contentSummary)
			contentSummary = re.sub("\t", " ", contentSummary)
			contentSummary = re.sub("\r", "", contentSummary)
			
			if (len(contentSummary) > 0):
				contentSummary = Formatter.data(format, 'summary', escape(contentSummary))[:-1]
		else:
			startTag = '<record>'
			endTag = '</record>'		
			if (len(contentSummary) > 0):
				contentSummary = Formatter.data(format, 'summary', escape(contentSummary))
		
		if (len(contentTitle) > 0):
			returnData += startTag + Formatter.data(format, 'title', escape(contentTitle))

		if (len(contentAltTitle) > 0):
			returnData += Formatter.data(format, 'alt_title', escape(contentAltTitle)) 

		if (len(contentSummary) > 0 ):
			returnData += contentSummary + endTag

		return returnData
開發者ID:,項目名稱:,代碼行數:66,代碼來源:

示例8: parseClinicalTrialsContent

# 需要導入模塊: import Formatter [as 別名]
# 或者: from Formatter import data [as 別名]
def parseClinicalTrialsContent(format,node):
	if (node):
		contentTitle = MutableString()
		contentLink = MutableString()
		contentSummary = MutableString()
		contentStatus = MutableString()
		contentTitle = ''
		contentLink = ''
		contentSummary = ''
		contentStatus = ''

		for content_node in node.childNodes:
			#get title
			if (content_node and content_node.nodeName == 'title'):
				for text_node in content_node.childNodes:
					contentTitle += text_node.nodeValue
			#get link
			if (content_node and content_node.nodeName == 'url'):
				for text_node in content_node.childNodes:
					contentLink += text_node.nodeValue
			#get status
			if (content_node and content_node.nodeName == 'status'):
				for text_node in content_node.childNodes:
					contentStatus += text_node.nodeValue
			#get content	
			if (content_node and content_node.nodeName == 'condition_summary'):
				for text_node in content_node.childNodes:
					contentSummary += text_node.nodeValue

		returnData = MutableString()
		returnData = ''			
		if (format == 'json'):
			startTag = '{'
			endTag = '},'

			#cleanup
			contentStatus = re.sub("\n", "", contentStatus)
			contentStatus = re.sub("\"", "\\\"", contentStatus)
			contentTitle = re.sub("\n", "", contentTitle)
			contentTitle = re.sub("\"", "\\\"", contentTitle)
			contentTitle = re.sub("\t", " ", contentTitle)
			contentLink = re.sub("\n", "", contentLink)
			contentLink = re.sub("\"", "\\\"", contentLink)
			contentSummary = re.sub("\"", "\\\"", contentSummary)
			contentSummary = re.sub("\n", "", contentSummary)
			contentSummary = re.sub("\t", " ", contentSummary)

			if (len(contentSummary) > 0):
				contentSummary = Formatter.data(format, 'summary', escape(contentSummary))[:-1]
		else:
			startTag = '<record>'
			endTag = '</record>'		
			if (len(contentSummary) > 0):
				contentSummary = Formatter.data(format, 'summary', escape(contentSummary))

		if (len(contentTitle) > 0):
			returnData += startTag + Formatter.data(format, 'title', escape(contentTitle))

		if (len(contentLink) > 0):
			returnData += Formatter.data(format, 'link', escape(contentLink)) 

		if (len(contentStatus) > 0):
			returnData += Formatter.data(format, 'status', escape(contentStatus))

		if (len(contentSummary) > 0 ):
			returnData += contentSummary + endTag

		return returnData
開發者ID:,項目名稱:,代碼行數:70,代碼來源:

示例9: parsePageContent

# 需要導入模塊: import Formatter [as 別名]
# 或者: from Formatter import data [as 別名]

#.........這裏部分代碼省略.........
			if (key in comments_stuff):
				tupComments = comments_stuff[key]
			else:
				tupComments = None
			if (tupURL):
				url = ''
				title = ''
				score = ''
				user = ''
				comments = ''
				timeAgo = ''
				itemId = ''
				itemInfo = ''
				
				#assign vars
				url = tupURL[0]
				title = tupURL[1]
				
				if (tupComments):
					score = tupComments[0]
					user = tupComments[1]
					comments = tupComments[2]
					timeAgo = tupComments[3]
					itemId = tupComments[4]
					itemInfo = tupComments[5]
				else:
					#need this for formatting
					itemInfo = 'n/a '
				
				#last record (either news2 or x?fnid)
				if (title.lower() == 'more' or '/x?fnid' in url):
					title = 'NextId'
					if ('/x?fnid' in url):
						url = '%s/format/%s/page/%s' % (apiURL, format, url.replace('/x?fnid=', ''))
					else:
						url = '/news2'
					itemInfo = 'hn next id %s ' % tupURL[0]
				
				if (format == 'json'):
					startTag = '{'
					endTag = '},'
					
					#cleanup
					if (title):
						title = re.sub("\n", "", title)
						title = re.sub("\"", "\\\"", title)
					
					if (itemInfo):
						itemInfo = re.sub("\"", "\\\"", itemInfo)
						itemInfo = re.sub("\n", "", itemInfo)
						itemInfo = re.sub("\t", " ", itemInfo)
						itemInfo = re.sub("\r", "", itemInfo)

					if (len(itemInfo) > 0):
						itemInfo = Formatter.data(format, 'description', escape(itemInfo))[:-1]
				else:
					startTag = '<record>'
					endTag = '</record>'
					if (len(title) > 0):
						title = escape(removeNonAscii(title))
						
					if (len(url) > 0):
						url = escape(url)
					
					if (len(user) > 0):
						user = escape(user)
						
					if (len(itemInfo) > 0):
						itemInfo = Formatter.data(format, 'description', escape(itemInfo))								

				if (len(title) > 0):
					returnData += startTag + Formatter.data(format, 'title', title)

				if (len(url) > 0):
					returnData += Formatter.data(format, 'url', url) 

				if (len(score) > 0):
					returnData += Formatter.data(format, 'score', score)
					
				if (len(user) > 0):
					returnData += Formatter.data(format, 'user', user)
				
				if (len(comments) > 0):
					returnData += Formatter.data(format, 'comments', comments)

				if (len(timeAgo) > 0):
					returnData += Formatter.data(format, 'time', timeAgo)
					
				if (len(itemId) > 0):
					#cleanup
					if ('item?id=' in itemId):
						itemId = itemId.replace('item?id=', '')
					returnData += Formatter.data(format, 'item_id', itemId)

				if (len(itemInfo) > 0 ):
					returnData += itemInfo + endTag
	else:
		returnData = None
	
	return returnData
開發者ID:suan,項目名稱:Hacker-News-Droid-API,代碼行數:104,代碼來源:APIUtils.py

示例10: parseCommentsContent

# 需要導入模塊: import Formatter [as 別名]
# 或者: from Formatter import data [as 別名]
def parseCommentsContent(hnAPIUrl, hnAPIUrlBackup, apiURL, page='',format='json'):
	returnData = MutableString()
	returnData = ''
	logging.debug('HN URL: %s' % hnAPIUrl)

	result = getRemoteData(hnAPIUrl, hnAPIUrlBackup)
	if (result):
		htmlData = result.content	
		soup = BeautifulSoup(htmlData)
		urlLinksContent = soup('table')
		counter = 0
		comment_container = {}
		for node in urlLinksContent:
			commentTd = node.first('td', {'class' : 'default'})
			if (commentTd):
				authorSpan = commentTd.first('span', {'class' : 'comhead'})
				#multi-paragraph comments are a bit tricky, parser wont' retrieve them using "span class:comment" selector
				commentSpan = getParagraphCommentSiblings(commentTd.first('span', {'class' : 'comment'}))
				replyLink = commentTd.first('a', {'href' : re.compile('^reply.*')})['href']
				if (replyLink and "reply?id=" in replyLink):
					replyLink = replyLink.replace('reply?id=', '')
				if (authorSpan and commentSpan):
					#author span: <span class="comhead"><a href="user?id=dendory">dendory</a> 1 day ago  | <a href="item?id=3015166">link</a></span>
					commentId = authorSpan.first('a', {'href' : re.compile('^item.*')})
					user = authorSpan.first('a', {'href' : re.compile('^user.*')})
					#get time posted...lame but works. for some reason authorSpan.string returns NULL
					timePosted = str(authorSpan).replace('<span class="comhead">', '').replace('</span>', '')
					#now replace commentId and user blocks
					timePosted = timePosted.replace(str(user), '').replace('| ', '').replace(str(commentId), '')
					if (commentId['href'] and "item?id=" in commentId['href']):
						commentId = commentId['href'].replace('item?id=', '')
					#cleanup
					commentString = removeHtmlTags(str(commentSpan))
					if ('__BR__reply' in commentString):
						commentString = commentString.replace('__BR__reply', '')
					comment_container[counter] = [commentId, user.string, timePosted.strip(), commentString, replyLink]
					counter = counter + 1
			
		#build up string	
		commentKeyContainer = {}	
		for key in comment_container.keys():
			listCommentData = comment_container[key]
			if (listCommentData and not commentKeyContainer.has_key(listCommentData[0])):
				commentId = listCommentData[0]
				if (commentId):
					commentKeyContainer[commentId] = 1
				userName = listCommentData[1]
				whenPosted = listCommentData[2]
				commentsString = listCommentData[3]
				replyId = listCommentData[4]
				
				if (format == 'json'):
					startTag = '{'
					endTag = '},'

					#cleanup
					if (commentsString):
						commentsString = re.sub("\"", "\\\"", commentsString)
						commentsString = re.sub("\n", "", commentsString)
						commentsString = re.sub("\t", " ", commentsString)
						commentsString = re.sub("\r", "", commentsString)

					if (len(commentsString) > 0):
						commentsString = Formatter.data(format, 'comment', escape(removeNonAscii(commentsString)))
					else:
						commentsString = "n/a "
				else:
					startTag = '<record>'
					endTag = '</record>'
					if (len(userName) > 0):
						userName = escape(removeNonAscii(userName))

					if (len(whenPosted) > 0):
						whenPosted = escape(whenPosted)

					if (len(commentsString) > 0):
						commentsString = Formatter.data(format, 'comment', escape(removeNonAscii(commentsString)))								

				if (commentId and userName and whenPosted and replyId and commentsString):
					if (len(commentId) > 0):
						returnData += startTag + Formatter.data(format, 'id', commentId)
							
					if (len(userName) > 0):
						returnData += Formatter.data(format, 'username', userName)

					if (len(whenPosted) > 0):
						returnData += Formatter.data(format, 'time', whenPosted)

					if (len(replyId) > 0):
						returnData += Formatter.data(format, 'reply_id', escape(replyId))

					if (len(commentsString) > 0 ):
						returnData += commentsString + endTag
	else:
		returnData = None

	return returnData
開發者ID:suan,項目名稱:Hacker-News-Droid-API,代碼行數:99,代碼來源:APIUtils.py


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