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


Java Parser類代碼示例

本文整理匯總了Java中org.jsoup.parser.Parser的典型用法代碼示例。如果您正苦於以下問題:Java Parser類的具體用法?Java Parser怎麽用?Java Parser使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: action

import org.jsoup.parser.Parser; //導入依賴的package包/類
public void action(JSONObject data) throws EventException {
	final JSONObject article = data.optJSONObject(Article.ARTICLE);

	String content = article.optString(Article.ARTICLE_CONTENT);

	final Document doc = Jsoup.parse(content, StringUtils.EMPTY, Parser.htmlParser());
	doc.outputSettings().prettyPrint(false);

	final StringBuilder listBuilder = new StringBuilder();

	listBuilder.append("<link rel=\"stylesheet\" type=\"text/css\" href=\"" + Latkes.getStaticServePath()
			+ "/plugins/list/style.css\" />");

	final Elements hs = doc.select("h1, h2, h3, h4, h5");

	listBuilder.append("<ul class='b3-solo-list'>");
	for (int i = 0; i < hs.size(); i++) {
		final Element element = hs.get(i);
		final String tagName = element.tagName().toLowerCase();
		final String text = element.text();
		final String id = "b3_solo_" + tagName + "_" + i;

		element.before("<span id='" + id + "'></span>");

		listBuilder.append("<li class='b3-solo-list-").append(tagName).append("'><a href='#").append(id)
				.append("'>").append(text).append("</a></li>");
	}
	listBuilder.append("</ul>");

	final Element body = doc.getElementsByTag("body").get(0);

	content = listBuilder.toString() + body.html();

	article.put(Article.ARTICLE_CONTENT, content);
}
 
開發者ID:daima,項目名稱:solo-spring,代碼行數:36,代碼來源:ArticleController.java

示例2: getAndSaveTranscript

import org.jsoup.parser.Parser; //導入依賴的package包/類
/**
 * Fetches captions/transcript for a given video
 * @param videoID to fetch
 * @param lang this captions should be in
 * @throws IOException
 */
public void getAndSaveTranscript(String videoID, String lang) throws IOException {

    lang = LanguageCode.convertIso2toIso1(lang);

    String url = captionEndPoint+"lang="+lang+"&v="+videoID;
    GetMethod get = new GetMethod(url);
    this.client.executeMethod(get);
    String xmlData = get.getResponseBodyAsString();

    //parse XML
    Document doc = Jsoup.parse(xmlData, "", Parser.xmlParser());
    String allCaps = "";
    for (Element e : doc.select("text")) {
        allCaps += e.text();
    }

    FileSaver file = new FileSaver(allCaps, lang, "youtube_caps", url, videoID);
    file.save(logDb);

}
 
開發者ID:gidim,項目名稱:Babler,代碼行數:27,代碼來源:YouTubeCaptionsScraper.java

示例3: videoHasCaptionsInLanguage

import org.jsoup.parser.Parser; //導入依賴的package包/類
/**
 * Checks if a given video has captions in our target language. As identified by the user who entered them
 * @param videoID to check
 * @param lang target
 * @return true if there are captions in lang
 * @throws IOException
 */
public boolean videoHasCaptionsInLanguage(String videoID, String lang) throws IOException {
    //visit captions index
    GetMethod get = new GetMethod(captionsIndex+videoID);
    this.client.executeMethod(get);
    String xmlData = get.getResponseBodyAsString();

    //parse XML
    Document doc = Jsoup.parse(xmlData, "", Parser.xmlParser());

    //iterate over all captions
    for (Element e : doc.select("track")) {
        String langCode = e.attr("lang_code");
        String fixedLangCode = LanguageCode.convertIso1toIso2(langCode);
        if(fixedLangCode.equals(lang))
            return true;
    }

    return false;
}
 
開發者ID:gidim,項目名稱:Babler,代碼行數:27,代碼來源:YouTubeCaptionsScraper.java

示例4: parseHtmlTemplate

import org.jsoup.parser.Parser; //導入依賴的package包/類
/**
 * Parse a given HTML template and return the a result object containing the expressions
 * and a transformed HTML.
 * @param htmlTemplate The HTML template to process, as a String
 * @param context Context of the Component we are currently processing
 * @return A {@link TemplateParserResult} containing the processed template and expressions
 */
public TemplateParserResult parseHtmlTemplate(String htmlTemplate,
    TemplateParserContext context)
{
    this.context = context;
    Parser parser = Parser.htmlParser();
    parser.settings(new ParseSettings(true, true)); // tag, attribute preserve case
    Document doc = parser.parseInput(htmlTemplate, "");

    result = new TemplateParserResult();
    processImports(doc);
    processNode(doc);

    result.setProcessedTemplate(doc.body().html());
    return result;
}
 
開發者ID:Axellience,項目名稱:vue-gwt,代碼行數:23,代碼來源:TemplateParser.java

示例5: doInBackground

import org.jsoup.parser.Parser; //導入依賴的package包/類
@Override
protected ArrayList<News> doInBackground(Void ...voids) {
    final ArrayList<News> newsList = new ArrayList<News>();
    try {
        final String endpoint = BASE_URL + NEWS_ENDPOINT;
        final Document doc = Jsoup.connect(endpoint).parser(Parser.xmlParser()).get();
        final Elements elements = doc.select("item");
        for (final Element element : elements) {
            final News news = new News();
            news.title = element.select("title").text();
            news.description = element.select("description").text();
            news.thumbnail = element.select("media|thumbnail").text();
            news.pubDate = element.select("pubDate").text();
            news.link = element.select("link").text();
            newsList.add(news);
        }
    } catch (IOException e){
        Log.e(TAG, "FetchNews error", e);
    }
    return newsList;
}
 
開發者ID:daose,項目名稱:KSAnime,代碼行數:22,代碼來源:MAL.java

示例6: removeHtmlTags

import org.jsoup.parser.Parser; //導入依賴的package包/類
public String removeHtmlTags(String markup) {
    
    String clean = preMatcher.matcher(markup).replaceAll(" ");
    clean = sourceMatcher.matcher(clean).replaceAll(" ");
    clean = syntaxMatcher.matcher(clean).replaceAll(" ");
    clean = commentMatcher.matcher(clean).replaceAll(" ");
    clean = monoTagMatcher.matcher(clean).replaceAll(" ");
    clean = fakeTagMatcher.matcher(clean).replaceAll(" ");
    
    try {
        Document document = Jsoup.parse(clean, "", Parser.xmlParser());
        document.select("math, gallery, ref, br, ins, s, del, tt, blockqoute, table").html(" ");
        clean = document.text();
    } catch(Exception e) {
        e.printStackTrace();
    }
    
    return clean;
}
 
開發者ID:crtomirmajer,項目名稱:wiki2mongo,代碼行數:20,代碼來源:MarkupCleaner.java

示例7: loadTrack

import org.jsoup.parser.Parser; //導入依賴的package包/類
private AudioTrack loadTrack(String videoId) {
  checkLoggedIn();

  try (HttpInterface httpInterface = getHttpInterface()) {
    try (CloseableHttpResponse response = httpInterface.execute(new HttpGet("http://ext.nicovideo.jp/api/getthumbinfo/" + videoId))) {
      int statusCode = response.getStatusLine().getStatusCode();
      if (statusCode != 200) {
        throw new IOException("Unexpected response code from video info: " + statusCode);
      }

      Document document = Jsoup.parse(response.getEntity().getContent(), StandardCharsets.UTF_8.name(), "", Parser.xmlParser());
      return extractTrackFromXml(videoId, document);
    }
  } catch (IOException e) {
    throw new FriendlyException("Error occurred when extracting video info.", SUSPICIOUS, e);
  }
}
 
開發者ID:sedmelluq,項目名稱:lavaplayer,代碼行數:18,代碼來源:NicoAudioSourceManager.java

示例8: getAllClasses

import org.jsoup.parser.Parser; //導入依賴的package包/類
@Override public List<String> getAllClasses() throws IOException, JSONException, CredentialInvalidException {
    String baseurl = data.getString(PARAM_BASEURL) + "/";

    for (int i = -4; i < MAX_DAYS; i++) {
        LocalDate date = LocalDate.now().plusDays(i);
        String dateStr = DateTimeFormat.forPattern("yyyyMMdd").print(date);
        String url = baseurl + "mobdaten/PlanKl" + dateStr + ".xml?_=" + System.currentTimeMillis();
        try {
            String xml = httpGet(url, "UTF-8");
            Document doc = Jsoup.parse(xml, url, Parser.xmlParser());

            List<String> classes = new ArrayList<>();
            for (Element klasse:doc.select("Klassen > Kl")) {
                classes.add(klasse.select("Kurz").first().text());
            }
            return classes;
        } catch (HttpResponseException e) {
            if (e.getStatusCode() != 404 && e.getStatusCode() != 300) throw e;
        }
    }
    return new ArrayList<>();
}
 
開發者ID:vertretungsplanme,項目名稱:substitution-schedule-parser,代碼行數:23,代碼來源:IndiwareMobileParser.java

示例9: wrongMetaCharsetFallback

import org.jsoup.parser.Parser; //導入依賴的package包/類
@Test
public void wrongMetaCharsetFallback() {
    try {
        final byte[] input = "<html><head><meta charset=iso-8></head><body></body></html>".getBytes("UTF-8");
        final ByteBuffer inBuffer = ByteBuffer.wrap(input);
        
        Document doc = DataUtil.parseByteData(inBuffer, null, "http://example.com", Parser.htmlParser());
        
        final String expected = "<html>\n" +
                                " <head>\n" +
                                "  <meta charset=\"iso-8\">\n" +
                                " </head>\n" +
                                " <body></body>\n" +
                                "</html>";
        
        assertEquals(expected, doc.toString());
    } catch( UnsupportedEncodingException ex ) {
        fail(ex.getMessage());
    }
}
 
開發者ID:cpusoft,項目名稱:common,代碼行數:21,代碼來源:DataUtilTest.java

示例10: normalXmlParse

import org.jsoup.parser.Parser; //導入依賴的package包/類
public static void normalXmlParse(){
    String json = CrawlerPack.getFromRemote(url);
    String xml = CrawlerPack.jsonToXml(json);

    // 原始 json 轉為 xml 的結果
    System.out.println( "原始XML" ) ;
    System.out.println( xml );

    Document jsoupDoc = Jsoup.parse(xml, "", Parser.xmlParser());
    jsoupDoc.charset(StandardCharsets.UTF_8);

    // 發生了什麼事?
    System.out.println( "轉換後XML" ) ;
    System.out.println(jsoupDoc.toString());


}
 
開發者ID:abola,項目名稱:CrawlerPack,代碼行數:18,代碼來源:Ch5Coz4.java

示例11: doInBackground

import org.jsoup.parser.Parser; //導入依賴的package包/類
@Override
protected String doInBackground(String... strings) {
    Document opmlDocument = null;
    try {
        if (mUrl != null) {
            opmlDocument = Jsoup.connect(mUrl).parser(Parser.xmlParser()).get();
        } else {
            opmlDocument = Jsoup.parse(mFile, "UTF-8");
        }
    } catch (IOException e) {
        e.printStackTrace();
        return e.getMessage();
    }
    if (opmlDocument != null) {
        mOpmlItems = opmlDocument.select("outline");
    }
    return "success";
}
 
開發者ID:crazyhitty,項目名稱:Munch,代碼行數:19,代碼來源:ImportOpmlInteractor.java

示例12: getDocument

import org.jsoup.parser.Parser; //導入依賴的package包/類
public static Document getDocument(String filepath) {
	Document doc = null;
	InputStream is = null;
	try {
		is = new FileInputStream(filepath);
	} catch (FileNotFoundException e1) {
		// TODO Auto-generated catch block
		System.out.println("FileUtils: no such XML file path exists");
		e1.printStackTrace();
		return null;
	}
	try {
		doc = Jsoup.parse(is, "UTF-8", "", Parser.xmlParser());
	} catch (Exception e) {
		System.out.println("Parse file to XML Document error!");
		e.printStackTrace();
	}
	return doc;
}
 
開發者ID:cusion,項目名稱:kongfzCrawler,代碼行數:20,代碼來源:FileUtils.java

示例13: getBranchRegex

import org.jsoup.parser.Parser; //導入依賴的package包/類
private static String getBranchRegex(String jobXml) {
    try {
        String branchRegex = Jsoup.parse(jobXml, "", Parser.xmlParser())
                .getElementsByTag("gerritProjects").get(0)
                .getElementsByTag(GERRITPROJECT_TAG).get(0)
                .getElementsByTag("branches").get(0)
                .getElementsByTag(BRANCH_TAG).get(0)
                .getElementsByTag("pattern").get(0).html();

        // Remove "^" and "$" at the beginning and the end, respectively
        branchRegex = branchRegex.substring(1, branchRegex.length() - 1);

        // Remove sections of regex that we add post-user-input
        branchRegex = branchRegex.replace("(?!refs/meta/)", "");
        branchRegex = branchRegex.replace("(?!refs/)", "refs/heads/");

        return branchRegex;
    } catch (IndexOutOfBoundsException e) {
        return null;
    }
}
 
開發者ID:palantir,項目名稱:gerrit-ci,代碼行數:22,代碼來源:JenkinsJobParser.java

示例14: parse

import org.jsoup.parser.Parser; //導入依賴的package包/類
private String parse(String str) {
    Document document = Jsoup.parse(str, "", Parser.xmlParser());
    String result = "";
    switch (outType) {
        case TYPE_TEXT:
            result = document.text();
            break;
        case TYPE_HTML:
            result = document.html();
            break;
        default:
            result = document.text();
            break;
    }
    return result;
}
 
開發者ID:fivesmallq,項目名稱:web-data-extractor,代碼行數:17,代碼來源:JerryExtractor.java

示例15: getUserInfo

import org.jsoup.parser.Parser; //導入依賴的package包/類
/**
 * Read information about user. Here you can read other important info.
 * @throws Exception 
 */
private void getUserInfo() throws Exception {
    //https://www.box.net/api/1.0/rest?action=get_auth_token&api_key=vkf3k5dh0tg1ibvcikjcp8sx0f89d14u&ticket=

    //https://www.box.net/api/1.0/rest?action=get_auth_token&api_key=vkf3k5dh0tg1ibvcikjcp8sx0f89d14u&ticket=xybt9orxzo1xrr5vk4r0axne804y1tpk

    NULogger.getLogger().log(Level.INFO, "{0} Getting auth token value............", getClass());
    httpGet = new NUHttpGet("https://www.box.net/api/1.0/rest?action=get_auth_token&api_key=vkf3k5dh0tg1ibvcikjcp8sx0f89d14u&ticket=" + ticket);
    httpResponse = httpclient.execute(httpGet, httpContext);
    responseString = EntityUtils.toString(httpResponse.getEntity());
    //NULogger.getLogger().log(Level.INFO, "{0}Response : {1}", new Object[]{getClass(), stringResponse});
    
    doc = Jsoup.parse(responseString, "", Parser.xmlParser());
    String auth_token = doc.select("response auth_token").text();

    NULogger.getLogger().log(Level.INFO, "{0} Auth_token : {1}", new Object[]{getClass(), auth_token});
    properties().setEncryptedProperty(KEY_AUTH_TOKEN, auth_token);
}
 
開發者ID:Neembuu-Uploader,項目名稱:neembuu-uploader,代碼行數:22,代碼來源:BoxDotComAccount.java


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