Dive Deep Into Python Vs Perl Debate – What Should I Learn Python or Perl?

Often when a new programming language is introduced, there is a debate that starts amongst some of the genius minds in the industry wherein the language is compared with the one already spreading its roots. A kind of buzz often spreads in the IT industry and the new one is often compared on every aspect may it then be features, syntax or core CPU and memory aspects including GC time and all, with the existing one of its kind.

Many examples of such cases can be picked up and investigated from the past including the debate between Java and C#, C++, etc. One such case which drew a significant amount of attention was the debate between two languages which came out one after the other in a short span i.e. Python and Perl.

Whereas Python was invented initially as a successor to ABC language merely as a “hobby” programming project (which would attract Unix/C hackers) for the author who named it after the series of his biggest star Monty Python.

Suggested Read: Getting Started with Python Programming and Scripting in Linux

Perl was just nearly around 2 years earlier as a Unix scripting language which intended to make report processing easier. It was a mixture of a combination of many languages including C, awk, sed, and shell script.

The thing which is worth noting is that these languages which evolved of different intentions are being constantly compared, which has made me study and figure out the reasons, of which some important ones are listed as below:

  1. Both targeted Unix Operating System, one for hackers and others to process reports.
  2. Both are object-oriented (Python being the more) and interpreted, with one being strongly typed and clear when it comes to coding i.e. Python, and other allowing ugly typing with braces for representing a block i.e. Perl
  3. Both are opposite in principle when we say, Perl has many ways of doing a single task while python focuses on one and only one way of doing things.

Python vs Perl – Features Compared

Let’s dive deep into this debate and try to figure out the overall aspects where these two languages differentiate from one another. Also, let’s try finding out the source of truth for many cliches which can be heard in the industry saying “Python is Perl with training wheels” or “Python is similar to Perl but different” so that we can try and conclude with an accurate solution to this never-ending debate.

1. Python’s Clean vs Perl’s Complex Syntax

Python takes a huge advantage over Perl when it comes to code readability. Python’s code is a lot clearer to understand than that of Perl even when reading code after years.

With indentation representing the block of code, and proper structuring, Python’s code is a lot cleaner. On the other hand, Perl borrows its syntax from various programming languages like C, shell scripting and even awk and sed filters when it comes to regular expressions.

Suggested Read: 15 Useful ‘sed’ Commands for Daily Linux System Administration Tasks

Apart from this, with ‘{‘ and ‘}’ representing a block of code and unnecessary addition of ‘;’ at the end of each line, code in Perl could become a problem to understand if you read it after months or years because of its allowance of ugly scripting.

2. Perl’s Built-in Vs Python’s 3rd Party Regex and OS Operations Support

Perl language borrows its syntax from C and other UNIX commands like sed, awk, etc. due to which it has way powerful and built-in regex support without importing any third-party modules.

Also, Perl can handle OS operations using built-in functions. On the other hand, Python has third-party libraries for both the operations i.e. re for regex and os, sys for os operations which need to be ensured before doing such operations.

Perl’s regex operations have ‘sed’ like syntax which makes it easy not only for search operations but also replace, substitute and other operations on a string can be done easily and swiftly than python where a person needs to know and remember the functions which cater to the need.

Example: Consider a program to search for a digit in the string in Perl and Python.

Import re
str = ‘hello0909there’
result = re.findall(‘\d+’,str)
print result
$string =  ‘hello0909there’;
$string =~ m/(\d+)/;
print “$& \n”

You see the syntax for Perl is way easy and inspired by sed command which takes advantage over Python’s syntax which imports third party module ‘re’.

3. Python’s Advanced OO Programming vs Perl’s One-Liners

One feature where Python overshadows Perl is its advanced OO programming. Python has extensive object-oriented programming support with clean and consistent syntax while the object OOP in Perl being outdated where the package is used as a substitute for classes.

Suggested Read: Getting Started with Python Django Web Framework

Also, writing OO code in Perl will add a lot more complexity to the code, which would eventually make code difficult to understand, even subroutines in Perl are very difficult to program and eventually difficult to understand later.

On the other hand, Perl is best for its one-liners which can be used on the command line for performing the various tasks. Also, Perl code can eventually do various tasks in fewer lines of code than python.

A shortcode example of both languages which highlights Perl ability to do more in less LOC:

with open(“data.csv”) as f:
for line in f:
print line,
except Exception as e:
print "Can't open file - %s"%e
open(FILE,”%lt;inp.txt”) or die “Can’t open file”;
while(<FILE>) {
print “$_”; } 

Pros and Cons – Python vs Perl

In this section, we will discuss the Pros and Cons of Python and Perl.

Python PROS:

  1. It has a clean and elegant syntax which makes this language a great choice as the first programming language for novices who want to have hands-on on any programming language.
  2. Has very advanced and inherent OO Programming, also thread programming in Python is way better than Perl.
  3. There are many application areas where Python is preferred and even it outperforms Perl. Like: Perl is preferred for CGI scripting but nowadays Python’s Django and web2py like web scripting languages are becoming more popular and have a huge attraction from the industry.
  4. Has several SWIG wrappers for different programming languages like CPython, IronPython and Jython and development of these has preceded the development of SWIG wrappers for Perl.
  5. Python code is always well indented and easy to read and understand even if you are reading someone else’s code or even your code after years.
  6. Python is good for various applications like Big Data, Infra Automation, Machine Learning, NLP, etc, it has huge support of active communities because of being Open Source.

Python CONS:

  1. There are few areas where execution in Python is usually slower than that of Perl including regex and string-based operations.
  2. Sometimes it is difficult to get the type of variable in Python as in cases of very large code, you have to go till the end to get a type of variable that gets hectic and complex.

Perl PROS:

  1. Perl has powerful one-liners and even ensures UNIX piping like syntax which can be used on the command line to perform various tasks, also it is influenced by Unix and its command-line programming so integrates many UNIX influenced commands in its coding.
  2. Perl is known for its powerful regex and string comparison operations as it is influenced by sed and awk like powerful UNIX tools. In the case of regex and string operations like substitution, matching, replacement, Perl outperforms python which would take a few lines of code to achieve the same. Also many file I/O operations, exception handling is done faster on Perl.
  3. When it comes to a language for report generation, Perl has always been in fame since its introduction as one of the main reasons for the author to develop language like Perl was for report generation.
  4. Many application areas where Perl finds its use are Network Programming, System Administration, CGI Scripting (here Python is overcoming Perl with Django and web2py), etc.
  5. It is easy to identify the type of variable with the symbols that Perl uses before them, like: ‘@’ identifies arrays and ‘%’ identifies hashes.

Perl CONS:

  1. Perl has a very complex code which makes it difficult to understand for a novice. Subroutines, and even other symbols like: ‘$`’, ‘$&’ etc are hard to understand and program for a less experienced programmer. Also, Perl code when read would be difficult and complex to understand unless you have a quality experience.
  2. OO Programming in Perl is a bit out of date as it has never been known for OO programming and many operations like threading are also less pronounced on Perl.


As seen above where both languages are good on their regard as per the applications they target, Python takes a bit of advantage over Perl as a first choice for a novice due to its clean and easy to understand code, whereas on other hand Perl outperforms Python when it comes to string manipulation operations and some advanced one-liners for UNIX like OS and various other operations it is known for.

So, in the end, it’s all upon the specific area you target. All your comments on this article are welcome and would request you to give your views on the topic if according to you Python wins or Perl.

If you liked this article, then do subscribe to email alerts for Linux tutorials. If you have any questions or doubts? do ask for help in the comments section.

If You Appreciate What We Do Here On TecMint, You Should Consider:

TecMint is the fastest growing and most trusted community site for any kind of Linux Articles, Guides and Books on the web. Millions of people visit TecMint! to search or browse the thousands of published articles available FREELY to all.

If you like what you are reading, please consider buying us a coffee ( or 2 ) as a token of appreciation.

Support Us

We are thankful for your never ending support.

54 thoughts on “Dive Deep Into Python Vs Perl Debate – What Should I Learn Python or Perl?”

  1. Hi Gunjit,

    Thanks for writing this article. Lately, I needed also to work with python, and I was wondering if there is really a killer feature in that language, which would explain why it is so popular. Until now I still didn’t find it. But the simpleness of Perl for processing files, especially with its built-in RegEx support is still superior. Then what always comes is this indentation nonsense.

    Python fanboys always claim that python code would be cleaner. What they try to sell as an advantage is the biggest disadvantage of python.

    1. As David G. already pointed out writing clean maintainable code has to do more with the programmer, than with the language. Nothing to add here.
    2. Giving whitespaces a syntactic meaning is complete “brainfuck“. Only esoteric languages like “whitespace” do this… and python.

    In most languages where you have braces (C, C++, JAVA, C#, Perl, …) or equivalents (e.g. begin … end) the code can be auto-formatted.

    • you can reformat the code at any time using smart editors or external tools.
    • editors normally will auto-indent to the correct location while typing. E.g. you type "if (...) {" it will jump automatically to the correct indentation. You write more code then type "}" end it will jump again to the high scope automatically.

    You lose most of these advantages because the editor does not know to what scope your commands belong without braces.

    The whole point of “python is cleaner“, because your code does not work anymore correctly without correct indentation is nonsense. The problem they tried to fix, is more or less non-existent due to smart editors and auto-formatting. Or do you code in notepad?

    Ugly code suffers from bad naming of variables, functions, missing comments, bad software architecture, not because of the wrong indentation. If it is indented wrong you can easily fix it. E.g. in Vim by selecting the code fragment or whole file and pressing "=". Done.

    I just needed to say that ;-)

    Back to Perl vs. Python. Both languages support the same features sets, more or less conveniently. While Perl has some cool built-in language features like RegEx, Diamond-Operator, Backquotes for executing commands (like in BASH), etc., in Python most of this is solved through external libraries.

    Working with arrays, tuples, or structured data work in both languages. Python supports OO programming, whereas in Perl this is more an extension that was not there from the beginning.

    When it comes to libraries both worlds offer almost everything (often through the same underlying C libraries). Perl and CPAN are very old, very stable, but today many packages are not maintained anymore. But often they still work, why not?

    In Python, I often had compatibility issues, because library designers cannot keep the API stable. This really sucks if you need to update the system, and applications are broken. In Python people now use virtualenv to work around these issues. But still, this is a workaround that should not be necessary. (Maybe programmers who cannot format code correctly should not write libraries…:-)

    Then there is this python 2 vs python 3 incompatibility. What the f**k. Never have seen such a major break in any other language.

    So why is Python so popular? IMO it is not the language itself. Major drivers are killer applications. Like Rails was for Ruby. In Python, I know two major killer applications. Numpy and Jupyter Notebook for scientific computation.

    In Perl, there would be PDL for this purpose, but it is much less known.

    Today you read so much about python, not much about Perl anymore. So it is clear to me that young people will learn python, not Perl anymore, even though technically I still don’t see that big advantage.

  2. Great article – thanks.

    One point about the language. When you say “Python’s code is lot more cleaner” it sounds a little clumsy. It could read better as “Python’s code is lot cleaner”


  3. Are you really a python programmer? In Perl you can create clean or ugly code, it is up to you. I mean, forget the “ugly” programming capacity of Perl and you will have a “python like” language. It is named freedom ;-)

  4. I think Perl’s OO support with Moose remains unsaid here. Moose is good enough that other programming languages have started copying it.

  5. Code cleanness and readability can not be seen as a feature of the language. It is rather limited to the programmer’s way of writing and experience to make code maintainable and readable. Perl’s syntax which is also common in other languages, makes it even familiar and understandable. The flexibility that Perl offers to write code in different ways is more of a strength than a weakness.

    • Exactly!

      Too bad, there is no way to put the thumb down on this brainwashing article.

      Pythoners hying Perl is like Americans hying Rusia.

  6. The example which is supposed to show the brevity of Perl over Python is bad: it just translates Python to Perl.

    The way to accomplish the task of printing every line in data.csv is the following:

    # perl -wnp -e '' data.csv

    That is to say, it takes 0 lines of Perl to do that vs. 6 lines of Python.

    And I say this as someone who doesn’t know Perl; I’m currently learning it from Tim Maher’s excellent Minimal Perl book, because I got tired of writing bash scripts with grep, awk, and sed – and writing a Python program for simple text processing tasks is often too verbose.

    From what I gathered, Perl is what one would be better off using instead of the aforementioned bash/grep/awk/sed combo: it was built for that purpose, and supports the syntax.

    On the other hand, I’ve used Python to write things like convex hull algorithm in 3D and scientific computing within the SAGE ecosystem; it was much more pleasant to do these things in Python than, say, Java or C++ (and clearly, it would be insane to do this in Perl).

  7. The biggest aid/hindrance to readability is, always has been, and always will be, source code commenting. I find that gobbledegook code can be written just as easily in Python as in Perl, or any other language come to that (including Cobol).

    There’s no substitute for extensive in-line comments. Comment your code and you can pick it up years later and immediately see what it’s doing. That’s true whether it’s written in Python, Perl, C#, Assembler, whatever.

    Python vs. Perl – not a fair contest, they should be used for different things.

    The biggest issue I’ve seen with Python is the evangelists who think it’s the best thing since sliced bread, and that they can do anything with it. Only last week I came across a system written in Python which runs a database driven dynamic website.

    It had to call in so many outside libraries and packages that it’s a total mess. Understood only by the guy who wrote it 5 years ago, and he has long since moved on. Basically it replaces Apache and PHP but goodness knows why (it’s running on a LAMP server!). Probably the guy thought it was a challenge to write it in totally the wrong language.

    I bet he was chuffed when he finished it – probably took him 3 months to write something which I could’ve done in PHP in 3 days. Use the right tool for the job. Python or Perl? Design the system first THEN choose the tool.

    OO programming in Python? No – wrong tool! Use a language where OO is innate, not one where it’s been tacked on as an afterthought.

    (p.s. comparing say Django or Web2Py with Perl is unfair – a derivative is not the same as raw Python)

  8. Some of these perl examples don’t really reflect what’s more-or-less standard in the Perl community at any time since Perl 5 came out (15 years ago).

    Keeping in mind the vision of TMTOWTDI, your second Perl example:

    open(FILE,”%lt;inp.txt”) or die “Can’t open file”;
    while() {
    print “$_”; }

    …really would be typically written as just:

    open (FILE, ”inp.txt”) or die “Can’t open file: $!”;
    print while ();

    As many others have pointed out, Perl has a huge amount of syntax flexibility despite its overtones of C heritage, and that allows people to write working code in a relatively ugly, inefficient, and/or hard-to-read manner, with syntax reflecting their experience with other languages.

    It’s not really a drawback that Perl is so expressive, but it does mean that the programmer should be as disciplined as the task warrants when writing it when it comes to understandable Perl idioms.

    • Thanks for Updating us with your knowledge and we would surely correct our code with the updated one as given by you.
      Stay Connected :-)

  9. 1) I’ve usually found that the clarity and elegance of a program have a lot more to do with the programmer than the programming language. People who develop clean solutions will do so regardless of the language of implementation. Likewise, those who can’t program will find a way to force an ugly solution out of any language.

    2) Most systems administrators aren’t programmers and have rarely had any formal training in software development.

    Put these two observations together and you will still get ugly, “write only” programs Before perl it was shell script, yesterday it was perl, today it’s Python. Tomorrow someone will be asking for a replacement for Python because it’s so hard to read and can’t be maintained. Get used to it (but don’t blame the programming language).

    I started my perl programming with perl 2.0 in 1993. It’s still my “go to” programming language since it doesn’t get in my way and I can get to a solution much faster than with C or shell script.

    • You pointed out, that those who are programmers would find out clean and understandable solutions out of any language, while non-programmers would stay on getting ugly solutions out of any language. Its really on the experience of person and his familiarity with any language.
      Thanks for sharing your views with us. Stay Connected :-)


Got something to say? Join the discussion.

Have a question or suggestion? Please leave a comment to start the discussion. Please keep in mind that all comments are moderated and your email address will NOT be published.

This site uses Akismet to reduce spam. Learn how your comment data is processed.