Extract table column values using xpath excluding












1















I am trying to scrap some table column values using scrapy and stuck on how to get a column value. The code right now is



response.xpath('//table//tr//td[4]//text()').extract()


It does extract the column values but the problem is some columns does have



<td> value 1 <sup> sup text </sup> </td> 


and the return values are value1 , sup text which is not what i do require .I need only i tried the code with td[4][not(sup)] but it does completely ignore the columns with <sup> .



Is there a way to get the values excluding <sup> .










share|improve this question























  • You've said what you DON'T want, but you haven't said what you DO want. For example, if the input is `<td>H<sub>2</sub>O</td>, what do you want the result to be?

    – Michael Kay
    Nov 22 '18 at 10:56











  • What i need was H , the answer below gives it

    – Anoop D
    Nov 22 '18 at 15:56











  • No, the answer you accepted returns two text nodes, containing "H" and "O" respectively. In some contexts (but we don't know the context) when you select two nodes, the second will be ignored. But in general if you only want the first text node then you should add a predicate [1].

    – Michael Kay
    Nov 22 '18 at 15:57













  • Sorry , it does works in my context ,........ the answer is not returning <sup> value , it works perfectly for me .

    – Anoop D
    Nov 23 '18 at 4:13


















1















I am trying to scrap some table column values using scrapy and stuck on how to get a column value. The code right now is



response.xpath('//table//tr//td[4]//text()').extract()


It does extract the column values but the problem is some columns does have



<td> value 1 <sup> sup text </sup> </td> 


and the return values are value1 , sup text which is not what i do require .I need only i tried the code with td[4][not(sup)] but it does completely ignore the columns with <sup> .



Is there a way to get the values excluding <sup> .










share|improve this question























  • You've said what you DON'T want, but you haven't said what you DO want. For example, if the input is `<td>H<sub>2</sub>O</td>, what do you want the result to be?

    – Michael Kay
    Nov 22 '18 at 10:56











  • What i need was H , the answer below gives it

    – Anoop D
    Nov 22 '18 at 15:56











  • No, the answer you accepted returns two text nodes, containing "H" and "O" respectively. In some contexts (but we don't know the context) when you select two nodes, the second will be ignored. But in general if you only want the first text node then you should add a predicate [1].

    – Michael Kay
    Nov 22 '18 at 15:57













  • Sorry , it does works in my context ,........ the answer is not returning <sup> value , it works perfectly for me .

    – Anoop D
    Nov 23 '18 at 4:13
















1












1








1








I am trying to scrap some table column values using scrapy and stuck on how to get a column value. The code right now is



response.xpath('//table//tr//td[4]//text()').extract()


It does extract the column values but the problem is some columns does have



<td> value 1 <sup> sup text </sup> </td> 


and the return values are value1 , sup text which is not what i do require .I need only i tried the code with td[4][not(sup)] but it does completely ignore the columns with <sup> .



Is there a way to get the values excluding <sup> .










share|improve this question














I am trying to scrap some table column values using scrapy and stuck on how to get a column value. The code right now is



response.xpath('//table//tr//td[4]//text()').extract()


It does extract the column values but the problem is some columns does have



<td> value 1 <sup> sup text </sup> </td> 


and the return values are value1 , sup text which is not what i do require .I need only i tried the code with td[4][not(sup)] but it does completely ignore the columns with <sup> .



Is there a way to get the values excluding <sup> .







python xpath scrapy






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Nov 22 '18 at 2:54









Anoop DAnoop D

493615




493615













  • You've said what you DON'T want, but you haven't said what you DO want. For example, if the input is `<td>H<sub>2</sub>O</td>, what do you want the result to be?

    – Michael Kay
    Nov 22 '18 at 10:56











  • What i need was H , the answer below gives it

    – Anoop D
    Nov 22 '18 at 15:56











  • No, the answer you accepted returns two text nodes, containing "H" and "O" respectively. In some contexts (but we don't know the context) when you select two nodes, the second will be ignored. But in general if you only want the first text node then you should add a predicate [1].

    – Michael Kay
    Nov 22 '18 at 15:57













  • Sorry , it does works in my context ,........ the answer is not returning <sup> value , it works perfectly for me .

    – Anoop D
    Nov 23 '18 at 4:13





















  • You've said what you DON'T want, but you haven't said what you DO want. For example, if the input is `<td>H<sub>2</sub>O</td>, what do you want the result to be?

    – Michael Kay
    Nov 22 '18 at 10:56











  • What i need was H , the answer below gives it

    – Anoop D
    Nov 22 '18 at 15:56











  • No, the answer you accepted returns two text nodes, containing "H" and "O" respectively. In some contexts (but we don't know the context) when you select two nodes, the second will be ignored. But in general if you only want the first text node then you should add a predicate [1].

    – Michael Kay
    Nov 22 '18 at 15:57













  • Sorry , it does works in my context ,........ the answer is not returning <sup> value , it works perfectly for me .

    – Anoop D
    Nov 23 '18 at 4:13



















You've said what you DON'T want, but you haven't said what you DO want. For example, if the input is `<td>H<sub>2</sub>O</td>, what do you want the result to be?

– Michael Kay
Nov 22 '18 at 10:56





You've said what you DON'T want, but you haven't said what you DO want. For example, if the input is `<td>H<sub>2</sub>O</td>, what do you want the result to be?

– Michael Kay
Nov 22 '18 at 10:56













What i need was H , the answer below gives it

– Anoop D
Nov 22 '18 at 15:56





What i need was H , the answer below gives it

– Anoop D
Nov 22 '18 at 15:56













No, the answer you accepted returns two text nodes, containing "H" and "O" respectively. In some contexts (but we don't know the context) when you select two nodes, the second will be ignored. But in general if you only want the first text node then you should add a predicate [1].

– Michael Kay
Nov 22 '18 at 15:57







No, the answer you accepted returns two text nodes, containing "H" and "O" respectively. In some contexts (but we don't know the context) when you select two nodes, the second will be ignored. But in general if you only want the first text node then you should add a predicate [1].

– Michael Kay
Nov 22 '18 at 15:57















Sorry , it does works in my context ,........ the answer is not returning <sup> value , it works perfectly for me .

– Anoop D
Nov 23 '18 at 4:13







Sorry , it does works in my context ,........ the answer is not returning <sup> value , it works perfectly for me .

– Anoop D
Nov 23 '18 at 4:13














1 Answer
1






active

oldest

votes


















1














You need



//td[4]/text()


to get child text node. Note that //td[4]//text() - returns descendant text nodes (including text from sup)






share|improve this answer























    Your Answer






    StackExchange.ifUsing("editor", function () {
    StackExchange.using("externalEditor", function () {
    StackExchange.using("snippets", function () {
    StackExchange.snippets.init();
    });
    });
    }, "code-snippets");

    StackExchange.ready(function() {
    var channelOptions = {
    tags: "".split(" "),
    id: "1"
    };
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function() {
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled) {
    StackExchange.using("snippets", function() {
    createEditor();
    });
    }
    else {
    createEditor();
    }
    });

    function createEditor() {
    StackExchange.prepareEditor({
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader: {
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    },
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    });


    }
    });














    draft saved

    draft discarded


















    StackExchange.ready(
    function () {
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53423227%2fextract-table-column-values-using-xpath-excluding-sup%23new-answer', 'question_page');
    }
    );

    Post as a guest















    Required, but never shown

























    1 Answer
    1






    active

    oldest

    votes








    1 Answer
    1






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    1














    You need



    //td[4]/text()


    to get child text node. Note that //td[4]//text() - returns descendant text nodes (including text from sup)






    share|improve this answer




























      1














      You need



      //td[4]/text()


      to get child text node. Note that //td[4]//text() - returns descendant text nodes (including text from sup)






      share|improve this answer


























        1












        1








        1







        You need



        //td[4]/text()


        to get child text node. Note that //td[4]//text() - returns descendant text nodes (including text from sup)






        share|improve this answer













        You need



        //td[4]/text()


        to get child text node. Note that //td[4]//text() - returns descendant text nodes (including text from sup)







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Nov 22 '18 at 6:20









        AnderssonAndersson

        38.9k103469




        38.9k103469
































            draft saved

            draft discarded




















































            Thanks for contributing an answer to Stack Overflow!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid



            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.


            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53423227%2fextract-table-column-values-using-xpath-excluding-sup%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            這個網誌中的熱門文章

            Xamarin.form Move up view when keyboard appear

            Post-Redirect-Get with Spring WebFlux and Thymeleaf

            Anylogic : not able to use stopDelay()