Converting strings Series to numeric one











up vote
0
down vote

favorite












I'm doing



X = data['x'].apply(lambda h: [int(h[i:i + 2], 16) for i in (0, 2 ,4)])


Where x has strings of hex colors, and I'd like to map them to RGB arrays (3 values each). After that, X hasdtype='object, and X.values is a numpy array of numpy arrays.



My final goal is making it an 3 * n numpy array and use it with sklearn.cluster.KMeans. What is the best way to achieving this?










share|improve this question




























    up vote
    0
    down vote

    favorite












    I'm doing



    X = data['x'].apply(lambda h: [int(h[i:i + 2], 16) for i in (0, 2 ,4)])


    Where x has strings of hex colors, and I'd like to map them to RGB arrays (3 values each). After that, X hasdtype='object, and X.values is a numpy array of numpy arrays.



    My final goal is making it an 3 * n numpy array and use it with sklearn.cluster.KMeans. What is the best way to achieving this?










    share|improve this question


























      up vote
      0
      down vote

      favorite









      up vote
      0
      down vote

      favorite











      I'm doing



      X = data['x'].apply(lambda h: [int(h[i:i + 2], 16) for i in (0, 2 ,4)])


      Where x has strings of hex colors, and I'd like to map them to RGB arrays (3 values each). After that, X hasdtype='object, and X.values is a numpy array of numpy arrays.



      My final goal is making it an 3 * n numpy array and use it with sklearn.cluster.KMeans. What is the best way to achieving this?










      share|improve this question















      I'm doing



      X = data['x'].apply(lambda h: [int(h[i:i + 2], 16) for i in (0, 2 ,4)])


      Where x has strings of hex colors, and I'd like to map them to RGB arrays (3 values each). After that, X hasdtype='object, and X.values is a numpy array of numpy arrays.



      My final goal is making it an 3 * n numpy array and use it with sklearn.cluster.KMeans. What is the best way to achieving this?







      pandas






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Nov 19 at 14:35

























      asked Nov 19 at 14:24









      galah92

      884816




      884816
























          1 Answer
          1






          active

          oldest

          votes

















          up vote
          0
          down vote













          After creating X, you can split up the data into 3 columns like this



          X = data['x'].apply(lambda h: [int(h[i:i + 2], 16) for i in (0, 2 ,4)])
          data[['R','G','B']] = pd.DataFrame(X.values.tolist(), index=X.index)


          so that



          data[['R','G','B']]


          has the result in three columns for further processing






          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',
            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%2f53376676%2fconverting-strings-series-to-numeric-one%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








            up vote
            0
            down vote













            After creating X, you can split up the data into 3 columns like this



            X = data['x'].apply(lambda h: [int(h[i:i + 2], 16) for i in (0, 2 ,4)])
            data[['R','G','B']] = pd.DataFrame(X.values.tolist(), index=X.index)


            so that



            data[['R','G','B']]


            has the result in three columns for further processing






            share|improve this answer

























              up vote
              0
              down vote













              After creating X, you can split up the data into 3 columns like this



              X = data['x'].apply(lambda h: [int(h[i:i + 2], 16) for i in (0, 2 ,4)])
              data[['R','G','B']] = pd.DataFrame(X.values.tolist(), index=X.index)


              so that



              data[['R','G','B']]


              has the result in three columns for further processing






              share|improve this answer























                up vote
                0
                down vote










                up vote
                0
                down vote









                After creating X, you can split up the data into 3 columns like this



                X = data['x'].apply(lambda h: [int(h[i:i + 2], 16) for i in (0, 2 ,4)])
                data[['R','G','B']] = pd.DataFrame(X.values.tolist(), index=X.index)


                so that



                data[['R','G','B']]


                has the result in three columns for further processing






                share|improve this answer












                After creating X, you can split up the data into 3 columns like this



                X = data['x'].apply(lambda h: [int(h[i:i + 2], 16) for i in (0, 2 ,4)])
                data[['R','G','B']] = pd.DataFrame(X.values.tolist(), index=X.index)


                so that



                data[['R','G','B']]


                has the result in three columns for further processing







                share|improve this answer












                share|improve this answer



                share|improve this answer










                answered Nov 19 at 15:14









                576i

                2,1831033




                2,1831033






























                     

                    draft saved


                    draft discarded



















































                     


                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function () {
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53376676%2fconverting-strings-series-to-numeric-one%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







                    Popular posts from this blog

                    Wiesbaden

                    Marschland

                    Dieringhausen