is there a way to iterate again within the for loop? For example:
for x in list:
if(condition):
#I\'d like to grab the next iteration of the lis
I suspect that your approach to parsing an if statement is not a good way to go about it. You will also find that you can't nest your IF statements nor put them all one one line. Here is how I would go about it.
a) Convert your language into a BNF form. For example, for an if statment it might be
ifstmnt ::= IF <condiftion> THEN <trueblock> [ ELSE <elseblock> ]
statment ::= ifstmnt | assignstment | whilestmnt | forstmnt
etc
b) Work out what you are waiting for at each point. After the IF, you read a condition until you see THEN.
c) Write a getNextToken routine that reads characters from your source, until it has a complete token. A token is a recognisable unit - IF, THEN, A number, a symbol. Every time it is called it returns the token into a buffer. It is usefull to have a type and a value returned as well - it will save you converting numbers in many places. A table driven approach is very fast and flexible.
d) Then write lots of little routines to recognise each type of statement. One for IF, one for condition, one for block, one for statement, one for expression etc. These will call each other and return when they have recognised the statement. For example, the condition expression recogniser will read a boolean expression and eat all names, AND, OR etc, until it looks ahead and sees THEN. It can't handle THEN so it exists, and the IF recoogniser finds the token is THEN, it reads the next and calls the recogniser for a block (which might expect BEGIN, lots of statments and then END).
e) Each routine collects the data it needs - condition, trueblock, falseblock, and handles it as required. A very common treatment is to create a tree representation of the program in memory. Programmer defined names are collected in a dictionary as they are defined, and checked as they are used.
f) A real compiler will then try to re-arange the tree to make things more efficent - but I suggest that is a future develoment
g) The final action is then to walk the tree, evaluating it in some way. If you are writng an interpreter you can calulate the values and store then as you go - store the values in the doctionary. If you are writting a true compiler you will need to generate a suitable output for the linker. That is a major task.
Check out YACC and LEX. They are tools designed to do parts of the job, and will save you time. The terms to help your research are "lexical analysis" "parser" and similar.
And good luck. Your project is non-trivial!
See also http://nedbatchelder.com/text/python-parsers.html