Equivalents were produced with the Free Edition of Java to Python Converter.
The closest thing in Python to an abstract method is an empty method:
Java | Python |
---|---|
public abstract class AbstractClass { public abstract void abstractMethod(); } |
class AbstractClass: def abstractMethod(self): pass |
The closest equivalent to Java anonymous inner classes in Python is to use a class which extends the corresponding interface (which is converted to a Python class).
Java | Python |
---|---|
public class TestClass { void testMethod() { MyInterface localVar = new MyInterface() { public void method1() { someCode(); } public void method2(int i, boolean b) { someCode(); } }; } } |
class TestClass: def testMethod(self): localVar = MyInterfaceAnonymousInnerClass(self) class MyInterfaceAnonymousInnerClass(MyInterface): def __init__(self, outerInstance): self._outerInstance = outerInstance def method1(self): someCode() def method2(self, i, b): someCode() |
You can convert Java arrays to Python's 'list'.
Unsized Array
Java | Python |
---|---|
int[] myArray; | myArray = [] |
Sized Array
Java | Python |
---|---|
int[] myArray = new int[2]; | myArray = [0 for _ in range(2)] |
Access Array Element
Java | Python |
---|---|
x = myArray[0]; | x = myArray[0] # no change |
Jagged Array
Java | Python |
---|---|
float[][] myArray = new float[][] {{x, y}}; | myArray = [[x, y]] |
Rectangular Array
Java | Python |
---|---|
int[][] myArray = { {10, 20, 30 ,40}, {50, 60, 70, 80, 90, 100}, {110, 120} }; |
myArray = [[10, 20, 30, 40], [50, 60, 70, 80, 90, 100], [110, 120]] |
Java requires statements to end with semi-colons and multi-statement blocks to be enclosed in braces, while Python only requires indentation to correspond to the logical block levels and block headers to end in colons. The current instance is only available within instance methods via the first parameter of the method, usually named 'self' by convention (static methods are distinguished by the @staticmethod decorator).
Java | Python |
---|---|
class FooClass { void instanceMethod() { if (fooCondition) { fooLogicOne(); fooLogicTwo(); } } } |
class FooClass: def instanceMethod(self): if fooCondition: fooLogicOne() fooLogicTwo() |
Java | Python |
---|---|
void casts() { x = (int)y; x = (float)y; x = (String)y; } |
def casts(self): x = int(y) x = float(y) x = str(y) |
ArrayLists/Lists
Java's java.util.ArrayList collection and Python's 'list' are very close equivalents.
Java | Python |
---|---|
void arrayLists() { ArrayList<Integer> myList = new ArrayList<>(); myList.add(1); myList.add(1, 2); int i = 1; myList.set(0, i); i = myList.get(0); } |
def arrayLists(self): myList = [] myList.append(1) myList.insert(1, 2) i = 1 myList[0] = i i = myList[0] |
HashMaps/Dictionaries
Java's java.util.HashMap collection and Python's 'dict' are very close equivalents.
Java | Python |
---|---|
void hashMaps() { HashMap<String, Integer> map = new HashMap<>(); String s = "test"; map.put(s, 1); int i = map.get(s); i = map.size(); boolean b = map.isEmpty(); map.remove(s); } |
def hashMaps(self): map = {} s = "test" map.update({s: 1}) i = map[s] i = len(map) b = not map map.pop(s) |
Python has a single comment format, starting with the '#' symbol. Multiline comments can also be created using triple quoted multiline strings.
Java | Python |
---|---|
// single-line comment foo(); // end-of-line comment /* comment over multiple lines */ |
# single-line comment foo() # end-of-line comment # comment # over multiple lines # # using multiline strings to simulate multiline comments: """ comment over multiple lines """ |
Local Variable
Java | Python |
---|---|
int myVar = 2; | myVar = 2 # Python infers the type |
Inferred Types
Inferred typing is available in Java 10, but Python always infers the type:
Java | Python |
---|---|
// Java 10: var myVar = 2; |
myVar = 2 |
Static Field
In Python, static fields are initialized at the class level:
Java | Python |
---|---|
class FooClass { public static int staticField = 7; } |
class FooClass: staticField = 7 |
Instance Field
In Python, instance fields are not listed at the class level and are qualified with the instance object, given by the first instance method parameter (usually named 'self' by convention):
Java | Python |
---|---|
class FooClass { public int instanceField = 2; } |
class FooClass: def __init__(self): self.instanceField = 2 |
Local Constant
Java | Python |
---|---|
final int myConst = 2; | MY_CONST = 2 # at method level — up to programmers to respect the naming convention and avoid changing it |
Class Constant
Java | Python |
---|---|
public static final int myConst = 2; | MY_CONST = 2 # at class level — up to programmers to respect the naming convention and avoid changing it |
Python constructors are named __init__, but a serious shortcoming of Python is the restriction of allowing only one constructor per class.
Java | Python |
---|---|
class Foo { public Foo() { } } |
class Foo: def __init__(self): pass |
Python allows default parameters, but Java does not. Overloaded methods are the only alternative in Java to default parameters.
Java | Python |
---|---|
public void defaultParam() { defaultParam(0); } public void defaultParam(int param) { ... } |
def defaultParam(self, param=0): ... |
Enums in Java have equivalents in Python using the 'enum' module:
Java | Python |
---|---|
public enum Simple { Foo, Bar } |
from enum import Enum class Simple(Enum): FOO = 0 BAR = 1 |
Java uses '==' for determining both value equality for primitive types and identity equality for other types. In Python, '==' is only for determining value equality and the 'is' operator is only used for identity equality. In both languages you should not rely on identity equality for strings due to string interning.
Java | Python |
---|---|
// value equality with primitives: int i = 1; int j = 1; boolean valuesIdentical = i == j; // identity equality with class types: Foo f = new Foo(); Foo g = f; boolean objectsIdentical = f == g; // strings: String s1 = "abc"; String s2 = s1; valuesIdentical = s1.equals(s2); // caution: Java string internment often // makes this true whenever 'equals' is true: objectsIdentical = s1 == s2; |
# value equality: i = 1 j = 1 valuesIdentical = i == j # identity equality f = Foo() g = f objectsIdentical = f is g # strings: s1 = "abc" s2 = s1 valuesIdentical = s1 == s2 # caution: Python string internment often # makes this true whenever '==' is true: objectsIdentical = s1 is s2 |
The Python try/except/finally scheme is equivalent to Java's try/catch/finally:
Java | Python |
---|---|
void exceptionHandling() { try { } catch (Foo f) { throw new Foo(); } catch (Bar) { throw new Bar(); } catch (Exc1 e1 | Exc2 e2) { throw new FooAck(); } catch (Exc3 | Exc4) { throw new AckBar(); } finally { } } |
def exceptionHandling(self): try: pass except Foo as f: raise Foo() except Bar: raise Bar() except (Exc1 as e1, Exc2 as e2): raise FooAck() except (Exc3, Exc4): raise AckBar() finally: pass |
The Python 'with' statement is a shortcut for a try/finally block. Java has the 'try with resources' statement, which operates on objects of type java.io.Closeable:
Java | Python |
---|---|
try (Foo f = new Foo()) { ... some logic } |
with Foo() as f: ... some logic |
Java | Python |
---|---|
if (conditionA) { } else if (conditionB) { } else { } |
if conditionA: pass elif conditionB: pass else: pass |
Java allows incrementing and decrementing integers within expressions, while Python doesn't. The following shows how Java to Python Converter handles some cases.
Java | Python |
---|---|
public void incrementDecrement() { i = ++j; i = j++; i = j--; i = s + --t; i = s + t--; i = s + ++t; i = s + t++; } |
def incrementDecrement(self): j += 1 i = j i = j j += 1 i = j j -= 1 t -= 1 i = s + t i = s + t t -= 1 t += 1 i = s + t i = s + t t += 1 |
Java | Python |
---|---|
public class one { protected int baseField = 1; public one(int i) { } public void baseMethod() { } } public class two extends one { public two() { super(0); } public final void method() { super.baseField = 2; super.baseMethod(); } } |
class one: def __init__(self, i): self.baseField = 1 def baseMethod(self): pass class two(one): def __init__(self): super().__init__(0) def method(self): # no 'final' equivalent self.baseField = 2 super().baseMethod() |
Defining Interfaces
Interfaces in Python are just classes with empty methods:
Java | Python |
---|---|
public interface MyInterface { void method(); } |
class MyInterface: def method(self): pass |
Implementing Interfaces
Java | Python |
---|---|
public class Foo implements MyInterface { public void method() { ... some code } } |
class Foo(MyInterface): def method(self): ... some code |
Java | Python |
---|---|
import foo.*; import ack.Bar; |
from foo import * from ack import Bar |
Expression Lambda
Java | Python |
---|---|
myVar = (String text) -> text.length(); | myVar = lambda text : len(text) |
Multi-statement Lambda
Java | Python |
---|---|
myVar = (Foo param1, Bar param2) -> { // ...multiple statements } |
No direct Python equivalent |
Java | Python |
---|---|
x = y && z; x = y || z; x = !y; i = j | k; i = j & k; i = j ^ k; |
x = y and z x = y or z x = not y i = j | k i = j & k i = j ^ k |
Java | Python |
---|---|
// while loop: while (while_condition) { foo(); // break and continue: if (b) break; else continue; } // do-while loop: do { foo(); } while (do_condition); // traditional for loop: for (int i = 0; i < 10; i++) { foo(); } // 'for each' loop: for (Foo f : FooList) { } |
# while loop: while while_condition: foo() # break and continue: if b: break else: continue # do-while loop: # Python doesn't have a do-while loop, so simulate it: condition = True while condition: foo() condition = do_condition # traditional for loop: for i in range(0, 10): foo() # 'for each' loop: for f in FooList: pass |
Java | Python |
---|---|
void exponentiation() { x = Math.pow(y, z); } void integerDivision() { // Java integer division always rounds towards 0: int i = -5; int j = 2; int result = i / j; // result is -2 } void modulusOperator() { // Java and Python '%' operators are only equivalent for positive numbers: int i = 2; int j = -3; int result = i % j; // result is 2 } void otherMathOperations() { x = Math.abs(y); // see the java.lang.Math class for many more functions: x = Math.cos(y); x = Math.E; x = Math.PI; } |
import math def exponentiation(self): x = y ** z def integerDivision(self): i = -5 j = 2 result = math.trunc(i / float(j)) # result is -2 # Python integer division rounds away from 0 when negative: result = i / j # result is -3 def modulusOperator(self): i = 2 j = -3 result = math.fmod(i, j) # result is 2 # Python modulus operator produces a different result: result = i % j # result is -1 def otherMathOperations(self): x = abs(y) # 'abs' is a built-in Python function # see the Python 'math' module for many more functions: x = math.cos(y) x = math.e x = math.pi |
Python instance methods have a first parameter indicating the instance ('self' is the convention for this parameter and not a keyword), and static methods have the '@staticmethod' decorator.
Java | Python |
---|---|
public void instanceMethod() { } public static void staticMethod() { } |
def instanceMethod(self): pass @staticmethod def staticMethod(): pass |
Java | Python |
---|---|
void method(String... args) { for (String x : args) { ... logic for each item in args } } |
def method(self, *args): for x in args: ... logic for each item in args |
Java static initializer blocks and Python code at the class level serve the same purpose.
Java | Python |
---|---|
class Foo { public static int field; static { ... logic to set 'field' value } } |
class Foo: field = 0 ... logic to set 'field' value |
Java | Python |
---|---|
String s = initValue; int i = s.indexOf(y); i = s.lastIndexOf(y); i = s.length(); boolean b = s.contains(y); s = s.substring(i); s = s.substring(i, j); b = s.endsWith(y); b = s.startsWith(y); s = s.toLowerCase(); s = s.toUpperCase(); s = s.stripLeading(); s = s.stripTrailing(); |
s = initValue i = s.find(y) i = s.rfind(y) i = len(s) b = y in s s = s[i:] s = s[i:j] b = s.endswith(y) b = s.startswith(y) s = s.casefold() s = s.upper() s = s.lstrip() s = s.rstrip() |
Python 3.10 has 'match' syntax, but if/elif/else is used prior to Python 3.10.
Java | Python |
---|---|
switch (pivot) { case 1: foo(); break; case 2: case 3: bar(); break; case 4: break; default: ack(); break; } |
Python 3.10: match pivot: case 1: foo() case 2 | 3: bar() case 4: pass case other: ack() Prior to Python 3.10: if pivot == 1: foo() elif pivot == 2 or pivot == 3: bar() elif pivot == 4: pass else: ack() |
Java | Python |
---|---|
result = condition ? truePart : falsePart; | result = truePart if condition else falsePart |
Java | Python |
---|---|
String s = """ multiline raw string"""; |
s = """multiline raw string""" |
Java | Python |
---|---|
// checking if 'f' is an instance of type 'Foo': boolean b = f instanceof Foo; // getting the reliable name of the type 'Foo' (unbroken if the type name changes): String s = Foo.class.getName(); |
# checking if 'f' is an instance of type 'Foo': b = isinstance(f, Foo) # getting the reliable name of the type 'Foo' (unbroken if the type name changes): s = Foo.__name__ |
Copyright © 2004 – 2025 Tangible Software Solutions Inc.