This application is a national stage application under 35 U.S.C. §371 of PCT/CN2009/072606, filed Jul. 3, 2009.
It is sometimes desired to extract text from a mark-up document. However, a problem arises in that it is difficult to distinguish meaningful or desired text from extraneous text frequently contained in the mark-up documents.
For example, it may be desired to extract text from a web page, wherein the meaningful text of the web page is the main text of the web page and the extraneous text of the web page is text forming one or more accompanying advertisements, decorations, navigation information, a header or footer of the web page etc.
It is an object of embodiments of the invention to at least mitigate one or more of the problems of the prior art.
Embodiments of the invention will now be described by way of example only, with reference to the accompanying figures, in which:
The presence of the other text 120 in the mark-up document 100 often makes it difficult to extract the main text 110 i.e. it is difficult to automatically distinguish the main text 110 and the other text 120. Embodiments of the present invention provide a method and apparatus for automatically identifying and extracting the main text 110 of a mark-up document 100, such as the main text 110 of a web page, which is an example of a mark-up document containing mark-up instructions in the form of HTML tags
In step 220, blocks of text delimited with predetermined mark-up tags such as HMTL tags <!-- -->, <HEAD>, <SCRIPT>, etc are deleted or removed from the mark-up document 100. That is, text between predetermined pairs of mark-up tags is deleted. In some embodiments of step 220 all carriage returns (CR) or line breaks are also removed from the document, such that the document effectively contains a single paragraph of text.
In step 230 one or more predetermined mark-up tags in the mark-up document 100 are replaced with carriage returns (CR) or line breaks. In particular, in step 230 block-level mark-up tags such as HTML tags <DIV>, <H1>-<H6>, <HR>, <OL>, <UL>, <LI>, <P>, <TD>, <TR>, <TABLE>etc. are replaced with carriage returns (CR). This has the effect of dividing sections of the mark-up document 100 separated with the block-level tags into blocks or paragraphs of text separated by line breaks.
In step 240 the remaining mark-up tags in the mark-up document 100 are removed, such that the document only contains text and carriage return characters. That is, the document contains one or more paragraphs of text separated by carriage returns. Further, extraneous whitespace e.g. multiple blank lines etc. are removed from the document. As a result, the document contains a series of text paragraphs separated by carriage return characters.
In step 250, a word count is determined for each paragraph in the document. The word count represents the number of words in each paragraph. The word count is determined for all paragraphs, that is for both the main text 320 and other text 320, since the location and extent of the main text 310 within the document has not yet been determined. The document P is represented as an ordered set of N paragraphs, as in Equation 1:
P={p1, p2, . . . , pN} Equation 1
The word count for each of the paragraphs pi(1≦i<N) is then determined, which is denoted by a positive integer ni for 1≦i<N.
In order to distinguish the main text 410, in step 260 the paragraph lengths in ni are normalised to within a range [0, 1] according to a greatest paragraph length in the document by equation 2:
wherein nmax is the maximum value of ni.
In step 270, the normalised paragraph lengths of ni′ are smoothed to form a set of smoothed paragraph lengths ni″ by equation 3:
wherein w is a predetermined smoothing weight. A smoothing weight w=2 may be chosen, although other values can be selected.
Equation 3 smoothes the normalised paragraphs lengths based upon weighted bins. A bin contains a plurality of values. First and last paragraphs (i=1 & i=N) are smoothed with reference to a single adjacent paragraph length, whereas intermediate paragraphs are smoothed with reference to the two immediately adjacent paragraphs i.e. preceding and following paragraphs. Each bin, denoted by the value of i is given a weight of 2 during calculation of that bin's value, whereas the one or two adjacent bins are effectively given a weight of 1 in Equation 3.
In step 280 the one or more paragraphs forming the main text 310 of the document 300 are determined. In step 280 two threshold paragraph lengths are determined by Equations 4 and 5:
wherein w is a predetermined weight (w′=2 by default), navg″ is the average value of all ni″, nmax″ is the maximum value of all ni″ and nmin″ is the minimum value of all ni″. Let P′={pk, pk+1, . . . , pN′} be a continuous subset of P.
It can be determined that P′ represents the main text in P if the following two conditions are satisfied:
According to Equations 4 and 5, paragraphs 39 to 51 are determined to contain the main text 310 which, although slightly greater than paragraphs 40 to 50, is a good approximation to the main text 310. In particular, a majority of the other text has been removed from the document 300 without omitting any of the main text 310. Whilst in the example illustrated in
The above-described embodiment of the invention determines the main text 310 of a mark-up document 300 when the one or more sections of main text 310 have a similar paragraph length. However, it is sometimes desired to extract a plurality of sections of main text from a mark-up document when the sections of main text have different paragraph lengths. For example, a blog is a mark-up document which includes a plurality of sections of main text which may be written by an author regarding different topics and thus each section is likely to have different paragraph lengths. Similarly, a forum may be a mark-up document containing textual contributions by different authors, wherein paragraph lengths of each author are likely to differ due to their respective writing styles.
The method 700 begins in step 705. In step 710 text delimited with pairs of predetermined mark-up tags is removed, as in step 220 shown in
In the example described with reference to FIGS. 6 and 8-11 after three iterations five sections of main text had been determined (two in the first two iterations and one in the third iteration). The total main text of the example mark-up document is determined to be paragraphs 11 to 97, whereas the actual main text contained in the mark-up document was paragraphs 12 to 80. Whilst not every paragraph of other text has been removed, all paragraphs of main text 810, 910, 1010 have been identified and a majority of the other text removed.
The apparatus 1200 comprises a processor 1210 for executing software instructions, the processor 1210 being communicatively coupled to a memory 1220 for storing data therein and an I/O device 1230 for transmitting/receiving data. The processor 1210 is arranged to receive a mark-up document 100 via the I/O device 1230 and to store the mark-up document in the memory 1220. The processor is operatively arranged to determine one or more paragraphs of main text 110 in the mark-up document 100 according to embodiments of the invention as described above.
Advantageously, embodiments of the present invention provide a means for quickly identifying main text of a mark-up document. Embodiments of the present invention achieve good accuracy in identifying main text within a mark-up document, even when the mark-up document contains a plurality of different sections of main text of varying paragraph lengths.
It will be appreciated that embodiments of the present invention can be realised in the form of hardware, software or a combination of hardware and software. Any such software may be stored in the form of volatile or non-volatile storage such as, for example, a storage device like a ROM, whether erasable or rewritable or not, or in the form of memory such as, for example, RAM, memory chips, device or integrated circuits or on an optically or magnetically readable medium such as, for example, a CD, DVD, magnetic disk or magnetic tape. It will be appreciated that the storage devices and storage media are embodiments of machine-readable storage that are suitable for storing a program or programs that, when executed, implement embodiments of the present invention. Accordingly, embodiments provide a program comprising code for implementing a system or method as claimed in any preceding claim and a machine readable storage storing such a program. Still further, embodiments of the present invention may be conveyed electronically via any medium such as a communication signal carried over a wired or wireless connection and embodiments suitably encompass the same.
All of the features disclosed in this specification (including any accompanying claims, abstract and drawings), and/or all of the steps of any method or process so disclosed, may be combined in any combination, except combinations where at least some of such features and/or steps are mutually exclusive.
Each feature disclosed in this specification (including any accompanying claims, abstract and drawings), may be replaced by alternative features serving the same, equivalent or similar purpose, unless expressly stated otherwise. Thus, unless expressly stated otherwise, each feature disclosed is one example only of a generic series of equivalent or similar features.
The invention is not restricted to the details of any foregoing embodiments. The invention extends to any novel one, or any novel combination, of the features disclosed in this specification (including any accompanying claims, abstract and drawings), or to any novel one, or any novel combination, of the steps of any method or process so disclosed. The claims should not be construed to cover merely the foregoing embodiments, but also any embodiments which fall within the scope of the claims.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/CN2009/072606 | 7/3/2009 | WO | 00 | 11/23/2011 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2011/000165 | 1/6/2011 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
6510441 | Kenninga | Jan 2003 | B1 |
7111000 | Wen et al. | Sep 2006 | B2 |
8196036 | Huang et al. | Jun 2012 | B2 |
8250464 | Dang et al. | Aug 2012 | B2 |
8321396 | Dill et al. | Nov 2012 | B2 |
8392820 | Tsai et al. | Mar 2013 | B2 |
20020078105 | Hamada et al. | Jun 2002 | A1 |
20030192011 | Williamson et al. | Oct 2003 | A1 |
20040133557 | Wen et al. | Jul 2004 | A1 |
20050050086 | Liu et al. | Mar 2005 | A1 |
20050071328 | Lawrence | Mar 2005 | A1 |
20080010583 | Lee | Jan 2008 | A1 |
20080201633 | Huang et al. | Aug 2008 | A1 |
20080282149 | Williamson et al. | Nov 2008 | A1 |
20080306941 | Dill et al. | Dec 2008 | A1 |
20100146381 | Tsai et al. | Jun 2010 | A1 |
Number | Date | Country |
---|---|---|
101329665 | Dec 2008 | CN |
101334789 | Dec 2008 | CN |
101346715 | Jan 2009 | CN |
Number | Date | Country | |
---|---|---|---|
20120066587 A1 | Mar 2012 | US |