
Previously On:
Remember articles on this blog are aimed at transforming you from a complete novice to intermediate level as Algorand developer using python programming language, so you will get the best explanation even my granny could understand, perhaps she's fuzzy and had dropped out of school in form 2. Algorand - blockchain technology protocol, is a smart contract platform that enables developers build and deploy decentralized applications free of tampering being a core benefit of blockchain functionality.
Let us extend our last code since we only generated a public/private key pair(see image below) key to do more things for us.
In the Python environment, we installed Algorand package on day-1 so we are able to use every functionalities that Algorand corporation had made available. The Algorand development kit is available in four different programming language - Python, Java, Go and JavaScript. If you do not understand some terminologies/jargon here, don't worry, I have explained the basics at the end of this tutorial.
To create a public/private key pair, we needed just two modules so we imported modules:
- accountand,
- algod
In the algod module, there is a class - AlgorandClient(expecting 3 arguments) available for us to connect to the network so we can test our code. However, these code do not run using python environment but via API (+ the secret token we got from purestake). So, you need to have internet connection for it to pass through unlike when you can run usual python code locally.
account module has a function named generate_account that expects two arguments to generate a wallet for us.
Note: Think of a wallet as a traditional bank account. To send you some cash, I'll need your account number and account name and most times your bank name or Swift/BIC code as adopted by different countries. A wallet or digital account as it may be addressed is simply the combination of your private key and address which is capable of holding compatible digital assets, in this case, it is ALGO Native Token including other compatible ones like the Tether USDt(USDT), Asia Reserve Currency Fund (ARCC) etc.
You sign a transaction using your private key. It is private to you alone and anyone can access your fund. But Algorand kits is quite flexible in way that as a developer, you can configure your application in a way that will prevent known form of financial malpractices. This is one of the reasons the network is robust.
Private Key/Mnemonic Phrase Relationship
mnemonic . One of the benefits of using Algorand's  provided module is because it is secure and directly provided by the team to ease developers' work.
Take a look at the above codes. I wrote three functions to:
- Convert the private key we generated, printed from - line 14(stored as private_key) to- mnemonic phrasein- line 19.
- Again, take the mnemonic phrase - - mnemonic_phrasefrom- line 21, convert it to- private keyin- line 26.
- Lastly, use same mnemonic key and transform it to - public keyin- line 33.
AttributeError : 'tuple' object has not attribute 'split'. But there is nowhere in our code we have used the function split(). That's one of the things you will have to deal with as a developer. Actually, it took me up to 30 minutes to figure this out. It may not be the case if you are smarter than me. Being smart here lies in your ability to debug.==> mnemonic = mnemonic.split() located in the path ==> File "C:\Users\bobman\AppData\Local\Programs\Python\Python37\lib\site-packages\algosdk\mnemonic.py", line 113. You'll find the path inside Algorand sdk, in mnemonic.py file.line 19. Comment out codes subsequent toline 23 and you finds out it runs successfully but for others. Try it before you continue.line 19 to run successfully.  def convertToMnemonicKey():
      return ("My Mnemonic phrase:", mnemonic.from_private_key(private_key))
' ' is treated as a character but in some cases, is ignored.But it has cost us some time here. Time they say is money nevertheless it worth it. By default, the 25 words are generated all choked together so, to make it readable, the function split(' ') is applied which separates the words adding just a space in between each consecutive word and none at the beginning or end of the string.Line 19 adds a space at the beginning of the string  totaling 26 words hence the error. Let us rewrite line 19 and we'll be fine.
- Locally : To run or develop locally mean to run without connecting to online tools. All to happen on PC or machine. 
- Function in Python is a an organized block of codes that can be reuse over and over again. It makes writing code very easy and less stressful as you do not have to rewrite set of codes again when you need to use them in future. All you need is create a - .pyextended file and settle it right there. It becomes a module. Use it later by importing the module and call the function. Functions in python are denoted with keyword- ==>- deffollowed by the- function name, the- opening and closing parentheses, a- semi-colonhit- ENTERkey, your IDE should automatically indent the next line(usually an- indentation= hitting the- space key4 times) but not the case if you are using text environment. Then, the function body.- def doSomething(): buy = "Buy some ALGO Token" return buy invest = doSomething() print(invest)
print statement instead of return, you only need to call the function. If you doSomething without the parentheses (), you will only doNothing. That's the rule. So, you've got to pay attention to parentheses so you can doSomething.def buyAlgoToken(amountToBuy):
       your_wallet_address = HXDVVGA5L366KNNMKW75GZLKVSB2THUOAD2SU3A7YRJSFTSFNPBFEIDT6Y
       your_balance = 2BTC
       algo_current_price = 0.00002405BTC
       if (your_balance > 0.095BTC):
            available_buy = (your_balance/algo_current_price)
                if (amountToBuy == available_buy or amountToBuy < available_buy):
                     return your_wallet_address.balance += amountToBuy
                else:
                      return("You have exceeded your buying capacity)
       else:
            return ("Please deposit some BTC")
      
buyAlgoToken(1.5BTC)
- Argument: This is a value that is passed into a function(also called method) at the time of calling it which can either be a - keywordtype or argument preceded by an identifier such as that in- (name=).
- Parameter: A parameter is different from argument even though they are similar. Parameter is a variable passed inside the parentheses at the point you are defining a function. In our code above, - amountToBuyis a parameter while- 1.5BTCis argument.
- Module: From learnpython, Modules in Python are simply Python files with a .py extension. The name of the module will be the name of the file. A Python module can have a set of functions, classes or variables defined and implemented. 




