How to install Steem-Python

in #programming7 years ago (edited)

What is Steem-python

Steem-python is a python framework build by the legendary @furion which has been adopted as the official python framework for Steem.

You can find the project on Git Hub.

Many bots and services use Steem-python to communicate with the Steem blockchain. The other popular library is SteemJS for Javascript.

Installing Python

To use Steem-python you need to have python installed. Most distributions have their own installation of python and it is highly likely it is already installed. I do not recommend using the default version of python and install a localized version of python that has better support and better tools.

We are going to install Anaconda which is the python distribution that is used by most data scientists and machine learning developers. Unless you are also doing machine learning, I would recommend using miniconda as it only installs a minimum amount of modules.

You can find the latest version of mini conda on their website.

At this time, the latest 64 bit Linux version is: Miniconda3-latest-Linux-x86_64.sh

Download miniconda

wget https://repo.continuum.io/miniconda/Miniconda3-latest-Linux-x86_64.sh

Set execute permissions

chmod +x Miniconda3-latest-Linux-x86_64.sh

Run installation

./Miniconda3-latest-Linux-x86_64.sh

During the installation, you will be asked to approve the license, the location, and if you want to update your bash profile script. The last question asking to update your bash profile is set to no, I recommend specifying yes so that the path to the binaries are updated in your bash profile.

Once the installation is finished, log out of SSH and log back in to update your path variable.

Install dependencies

sudo apt install libffi-dev libssl-dev

Install Steem-python

The official steem-python distribution isn't updated very often and I recommend installing @furion's version of Steem-python. In fact the official version of Steem-python is originally @furion's work.

python3 -m pip install -U git+git://github.com/Netherdrake/steem-python

Optional (Install bPython)

bpython is a replacement for the python interactive console. It has syntax highlighting and some additional features like code intelligence. It is really helpful when working interactively with Python.

python3 -m pip install -U bpython

Test installation

If you installed bpython

bpython

If not

python

Enter the following program:

from steem import Steem
steem = Steem()
steem.get_account('ned')

If you see JSON returned, you are good to go!

themarkymark.png

My recent popular posts

Sort:  

That gives me an idea.
I hope you will not beat me to it:
steem-python the hard way, compiled by hand.. On Debian Wheezy..
:))

Nice post beautiful presented and explained.@themarkmark thanks for dawonload link and total very helpfull information sir

                    RESTEEM DONE !!!

Yes good boss @anak123


I'm new here. Check out my page and vote me✌Thank you so much @themarkymark. This post has helped a great deal. I feel like I could get better using the python programming lang.

Thanks for this great and vital information, it'll come in handy and very vital to a lot of persons most especially the developers, programmers or coders.


Unless you are also doing machine learning, I would recommend using miniconda as it only installs a minimum amount of modules.

Most especially, I've learnt from this ☝️as I didn't know about this before now.

Thanks for sharing this and

Happy Steeming

owo excellant post sir @themarkmark thanks for install information

I dont have a PC yet! Hopefully i can someday get one with my earnings from this great community

Thanks for sharing this, @furion did talk about the steem pyton in one of his recent posts.


I was not interested in this steem-python to tell you honestly..ill just drop by to say..Hello @themarkymark..

You already cast my vote as a witness.😀

Thanks @themarkymark for that short explanation on python

Hello @themarkymark, I am a new member in steemit and have not understood with the work of this application, what results will I get for my account if I use this application? please guidance his 😊

If you have to ask that, you can safely ignore this post.

Thank you so so much these information was really helpful to me
Thank you

well explined !! thanq :)

This post has received gratitude of 6.16 % from @appreciator thanks to: @themarkymark.

This development will trigger me the more to work hard and earn more on steemit so i can get a system to enable me to use this app. Thumbs up @themarkymark

These posts are so important to get techy guys interested in programming for our beloved platform. Thanks for doing this, I will forward the link to some programmers I know who are looking for a way in.


t.

Downloading steem-python now!!... it sounds very useful to me.

Is there anything that can't be done in Phyton.

Prepare some coffee...? Ok, yes, Python operated...

This post has been deemed resteem & upvote worthy by your friendly @eastcoaststeem ran by Steemian @chelsea88

Thanks
Your post is helpful
@syedazunaira250

Great! Once i'm done with my data science projects and then a couple of MQL4 ones it's time to explore the steem blockchain.

@themakymark is there any platform or discord server for mentoring the programmers for blockchain??

SteemDevs is the programmer's Discord for Steemit.

Few days ago I had a problem, I could not get steem-python work on my Linux computer. (Manjaro) I tried all posted solutions and nothing worked until I saw, this solution you mentioned to someone else few days ago:

python3 -m install -U git+git://github.com/Netherdrake/steem-python

This is what finally did it for me. Thanks

Thanks! Can't wait to try it out!

Thanks for posting!
It helped me to resort https://github.com/p-alik/steemBot

Edit: This is good work, thank you for answering my questions/concerns relating to this.

For anyone that attempts this method, I just loaded up a vbox to try it (ubuntu 16.04) and confirm it works. I received some errors with the command python3 -m install -U git+git://github.com/Netherdrake/steem-python stating the python3 had no module install. Miniconda installs a pip client so you can simply use pip install git+git://github.com/Netherdrake/steem-python and you will have the same results but the reason for the error is in the miniconda environment configuration you have to allow it to source to pip first. You should also be able to use the conda install -U git+git://github.com/Netherdrake/steem-python command and receive the same result (you do not need the -m for conda as you do not need to forward the module into it)

One of the things is that there is still a dependency issue with TOML where it says it requires a version that technically doesn't exist.

Second, and more importantly, is the steem-python library (unless set otherwise with the steem-cli wallet) automatically attempts to connect to depreciated servers.

Now unless these issues have been changed in the past, Idk, 7 days (I had to format my hard drive and reinstall it, 7 days ago and fix these issues) then your tutorial is misleading and will lead to a lot of errors that are going to frustrate first time devs. It is also important to note that steem-python runs on python3.6 (and later) and this important note comes from you using the python command when it is more accurate to state python3.6 as many linux systems (like ubuntu) come with python2.7.X preinstalled and is using it for system dependencies (meaning uninstalling will lead to problems) and defaults the python command to python2.7

This can be fixed using the command: alias python=python3.6
However this fix may lead to issues when the OS goes to run one of the system python scripts as some configurations use the python default command instead of the version specific. This can be changed with configurations (and I believe was fixed a few version back in ubuntu but other distros may still have problems)

This isn't a criticism or stating that you are incorrect, just stating that there is some information that is potentially crucial for new users (like the ones that will need a tutorial on installing this) and that without it.

A few problems with this tutorial there @themarkymark

These issues are resolved in @furion’s version and conda, but something I would do manually with the official version.

Okay, I didn't realize the TOML issue (or the default node) were changed in furions version, my bad.

Yeah, did it by hand before and helped many people doing it for their witness feeds and it was a huge pain. The nodes are fixed as well in this version but I still set them to my own full node and the ones I choose as api.steemit.com is very buggy.

Sorry the pip was left out in the command so it was looking for install module not pip. I fixed it after I posted it but it didn’t seem to save.

python3 -m pip install

I use that because I want to be sure it is using conda’s python and not system. Conda works as well but wanted to keep it simple.

No worries, I am glad it got fixed to prevent any confusion!

As I said there was a way to bypass this with environment configurations but I thought that would be more confusing to post about. Thanks for making this btw, it will likely help others out a lot!

Yeah didn't want to touch ENVs as I wanted to keep it simple and most people won't be using them.

One of the things is that there is still a dependency issue with TOML where it says it requires a version that technically doesn't exist.

The git version by furion fixes this issue. I installed it recently.

Plus installing the latest Miniconda3 should have the newest python. Do not remember if i needed to upgrade it after.

I have never used miniconda3 (I am not a big fan of python to begin with so I do not see why I would download more stuff for it 🍌)

But there is some fear, if it updates the default alias, as many systems are configured to call python to run python2.7 scripts so if you are on a misconfigured system (a lot are) then you run the risk of many system errors if this method overrides the default alias.

yes, but it is only for the local user as it is a localized version and not systemwide.

Okay that makes more sense. My apologies