Python - por que posso importar módulos sem __init__.py?

Eu sou novo no Python e ainda não consigo entender por que precisamos de um__init__.py arquivo para importar módulos. Passei por outras perguntas e respostas, comoesta.

O que me confunde é que eu posso importar meus módulossem __init__py, tãopor que eu preciso disso?

Meu exemplo

index.py
   modules/
      hello/
          hello.py
          HelloWorld.py

index.py,

import os
import sys

root = os.path.dirname(__file__)
sys.path.append(root + "/modules/hello")

# IMPORTS MODULES
from hello import hello
from HelloWorld import HelloWorld

def application(environ, start_response):

    results = []

    results.append(hello())

    helloWorld = HelloWorld()
    results.append(helloWorld.sayHello())

    output = "<br/>".join(results)

    response_body = output

    status = '200 OK'

    response_headers = [('Content-Type', 'text/html'),
                       ('Content-Length', str(len(response_body)))]

    start_response(status, response_headers)

    return [response_body]

modules / hello / hello.py,

def hello():
    return 'Hello World from hello.py!'

modules / hello / HelloWorld.py,

# define a class
class HelloWorld:
    def __init__(self):
        self.message = 'Hello World from HelloWorld.py!'

    def sayHello(self):
        return self.message

Resultado,

Hello World from hello.py!
Hello World from HelloWorld.py!

O que é preciso são apenas essas duas linhas,

root = os.path.dirname(__file__)
sys.path.append(root + "/modules/hello")

Sem nenhum__init__py. Alguém pode explicar por que funciona dessa maneira?

E se__init__py é a maneira correta, o que devo fazer / alterar no meu código?

questionAnswers(5)

yourAnswerToTheQuestion