Em que SO estou a correr?

O que preciso de ver para ver se I'm no Windows ou Unix, etc?

Comentários sobre a pergunta (2)
Solução
>>> import os
>>> print os.name
posix
>>> import platform
>>> platform.system()
'Linux'
>>> platform.release()
'2.6.22-15-generic'

A saída de platform.system() é a seguinte:

  • Linux: Linux
  • Mac: 'Darwin'
  • Janelas: `Windows'.

Ver: plataforma - Acesso aos dados de identificação da plataforma subjacente

Comentários (6)

Dang -- a lbrandy venceu-me, mas isso não'isso não significa que eu possa'não lhe forneça os resultados do sistema para o Vista!

>>> import os
>>> os.name
'nt'
>>> import platform
>>> platform.system()
'Windows'
>>> platform.release()
'Vista'

...e ainda não acredito que ninguém tenha postado um para o Windows 10:

>>> import os
>>> os.name
'nt'
>>> import platform
>>> platform.system()
'Windows'
>>> platform.release()
'10'
Comentários (4)

Para que conste aqui's os resultados em Mac:

>>> import os
>>> os.name
'posix'
>>> import platform
>>> platform.system()
'Darwin'
>>> platform.release()
'8.11.1'
Comentários (0)

Exemplo de código para diferenciar OS's usando python:

from sys import platform as _platform

if _platform == "linux" or _platform == "linux2":
   # linux
elif _platform == "darwin":
   # MAC OS X
elif _platform == "win32":
   # Windows
elif _platform == "win64":
    # Windows 64-bit
Comentários (5)

Você também pode utilizar sys.platform se você já importou sys e não'não quer importar outro módulo

>>> import sys
>>> sys.platform
'linux2'
Comentários (2)

Se você quiser dados legíveis pelo usuário, mas ainda detalhados, você pode usar [platform.platform()][1]

>>> import platform
>>> platform.platform()
'Linux-3.3.0-8.fc16.x86_64-x86_64-with-fedora-16-Verne'

[1]: http://docs.python.org/library/platform.html#platform.platform

Aqui's algumas chamadas diferentes possíveis que você pode fazer para identificar onde você está

import platform
import sys

def linux_distribution():
  try:
    return platform.linux_distribution()
  except:
    return "N/A"

print("""Python version: %s
dist: %s
linux_distribution: %s
system: %s
machine: %s
platform: %s
uname: %s
version: %s
mac_ver: %s
""" % (
sys.version.split('\n'),
str(platform.dist()),
linux_distribution(),
platform.system(),
platform.machine(),
platform.platform(),
platform.uname(),
platform.version(),
platform.mac_ver(),
))

As saídas deste script rodaram em alguns sistemas diferentes (Linux, Windows, Solaris, MacOS) e arquiteturas (x86, x64, Itanium, power pc, sparc) está disponível aqui: https://github.com/hpcugent/easybuild/wiki/OS_flavor_name_version

Ubuntu 12.04 servidor, por exemplo, dá:

Python version: ['2.6.5 (r265:79063, Oct  1 2012, 22:04:36) ', '[GCC 4.4.3]']
dist: ('Ubuntu', '10.04', 'lucid')
linux_distribution: ('Ubuntu', '10.04', 'lucid')
system: Linux
machine: x86_64
platform: Linux-2.6.32-32-server-x86_64-with-Ubuntu-10.04-lucid
uname: ('Linux', 'xxx', '2.6.32-32-server', '#62-Ubuntu SMP Wed Apr 20 22:07:43 UTC 2011', 'x86_64', '')
version: #62-Ubuntu SMP Wed Apr 20 22:07:43 UTC 2011
mac_ver: ('', ('', '', ''), '')
Comentários (0)

Que tal uma nova resposta?

import psutil
psutil.MACOS   #True (OSX is deprecated)
psutil.WINDOWS #False
psutil.LINUX   #False 

Esta seria a saída se eu estivesse usando MACOS

Comentários (4)

Eu estou usando a ferramenta WLST que vem com o weblogic, e ela não't implementa o pacote da plataforma.

wls:/offline> import os
wls:/offline> print os.name
java 
wls:/offline> import sys
wls:/offline> print sys.platform
'java1.5.0_11'

Além de remendar o sistema javaos.py ([issue with os.system() on windows 2003 with jdk1.5][1]) (que eu posso't fazer, eu tenho que usar o weblogic fora da caixa), isto é o que eu uso:

def iswindows():
  os = java.lang.System.getProperty( "os.name" )
  return "win" in os.lower()

[1]: http://osdir.com/ml/lang.jython.devel/2006-08/msg00035.html

Comentários (0)

Para Jython a única maneira de obter o nome que encontrei foi verificando a propriedade Java os.name (experimentado com módulos sys, os e platform para Jython 2.5.3 no WinXP):

def get_os_platform():
    """return platform name, but for Jython it uses os.name Java property"""
    ver = sys.platform.lower()
    if ver.startswith('java'):
        import java.lang
        ver = java.lang.System.getProperty("os.name").lower()
    print('platform: %s' % (ver))
    return ver
Comentários (1)

/usr/bin/python3.2

def cls():
    from subprocess import call
    from platform import system

    os = system()
    if os == 'Linux':
        call('clear', shell = True)
    elif os == 'Windows':
        call('cls', shell = True)
Comentários (2)

Comecei uma listagem um pouco mais sistemática dos valores que você pode esperar usando os vários módulos (sinta-se à vontade para editar e adicionar o seu sistema):

Linux (64bit) + WSL

os.name posix
sys.platform linux
platform.system() Linux
sysconfig.get_platform() linux-x86_64
plataforma.máquina() x86_64
platform.architecture() ('64bit', '')
  • Tentei com archlinux e menta, obtive os mesmos resultados
  • no python2 sys.platform é sufixado pela versão do kernel, por exemplo linux2, tudo o resto permanece idêntico
  • mesma saída no subsistema Windows para Linux (experimentado com ubuntu 18.04 LTS), exceto platform.architecture() = ('64bit', 'ELF')

WINDOWS (64bit)

(com a coluna 32bit em funcionamento no subsistema 32bit)

instalador oficial de pitões 64bit 32bit
-------------------------   -----                     -----
os.name nt nt nt
sys.platform win32 win32
plataforma.sistema() Windows Windows
sysconfig.get_platform() win-amd64 win32
plataforma.máquina() AMD64 AMD64
platform.architecture() ('64bit', 'WindowsPE') ('64bit', 'WindowsPE')

msys2 64bit 32bit
-----                       -----                     -----
os.name posix posix
sys.platform msys msys
platform.system() MSYS_NT-10.0 MSYS_NT-10.0-WOW
sysconfig.get_platform() msys-2.11.2-x86_64 msys-2.11.2-i686
platform.machine() x86_64 i686
platform.architecture() ('64bit', 'WindowsPE') ('32bit', 'WindowsPE')

msys2 msys2 mingw-w64-x86_64-python3 mingw-w64-i686-python3
-----                       ------------------------  ----------------------
os.name nt nt nt
sys.platform win32 win32
plataforma.sistema() Windows Windows
sysconfig.get_platform() mingw mingw
plataforma.máquina() AMD64 AMD64
platform.architecture() ('64bit', 'WindowsPE') ('32bit', 'WindowsPE')

cygwin 64bit 32bit
------                      -----                     -----
os.name posix posix
sys.platform cygwin cygwin
platform.system() CYGWIN_NT-10.0 CYGWIN_NT-10.0-WOW
sysconfig.get_platform() cygwin-3.0.1-x86_64 cygwin-3.0.1-i686
platform.machine() x86_64 i686
platform.architecture() ('64bit', 'WindowsPE') ('32bit', 'WindowsPE')

Algumas observações:

  • há também distutils.util.get_platform() que é idêntica a `sysconfig.get_platform
  • anaconda em janelas é igual ao instalador oficial de janelas python
  • Eu não'não tenho um Mac nem um verdadeiro sistema de 32bit e não estava motivado a fazê-lo online

Para comparar com o seu sistema, simplesmente execute este script (e por favor anexe os resultados aqui se faltarem :)

de __futuro__impressão_impressão_função
os de importação
sistema de importação
plataforma de importação
sysconfigurar importação

print("os.name ", os.name)
print("sys.platform ", sys.platform)
print("platform.system() ", platform.system())
print("sysconfig.get_platform() ", sysconfig.get_platform())
print("platform.machine() ", platform.machine())
print("platform.architecture() ", platform.architecture())
Comentários (0)

Cuidado se você'está no Windows com o Cygwin onde os.name é posix.

>>> import os, platform
>>> print os.name
posix
>>> print platform.system()
CYGWIN_NT-6.3-WOW
Comentários (0)

Resultados interessantes em janelas 8:

>>> import os
>>> os.name
'nt'
>>> import platform
>>> platform.system()
'Windows'
>>> platform.release()
'post2008Server'

Edit: That's a bug

Comentários (0)

na mesma linha...

import platform
is_windows=(platform.system().lower().find("win") > -1)

if(is_windows): lv_dll=LV_dll("my_so_dll.dll")
else:           lv_dll=LV_dll("./my_so_dll.so")
Comentários (2)

Se você não está procurando a versão do kernel etc, mas procurando a distribuição linux, você pode querer usar o seguinte

em python2.6+

>>> import platform
>>> print platform.linux_distribution()
('CentOS Linux', '6.0', 'Final')
>>> print platform.linux_distribution()[0]
CentOS Linux
>>> print platform.linux_distribution()[1]
6.0

em python2,4

>>> import platform
>>> print platform.dist()
('centos', '6.0', 'Final')
>>> print platform.dist()[0]
centos
>>> print platform.dist()[1]
6.0

Obviamente, isto só funcionará se você estiver executando isto no linux. Se você quiser ter um script mais genérico através de plataformas, você pode misturá-lo com amostras de código dadas em outras respostas.

Comentários (0)

Experimenta isto:

import os

os.uname()

e você pode fazer isso :

info=os.uname()
info[0]
info[1]
Comentários (2)

Existem 3 maneiras de obter OS em Python, cada uma com seus próprios prós e contras:

**Método 1***

>>> import sys
>>> sys.platform
'win32'  # could be 'linux', 'linux2, 'darwin', 'freebsd8' etc

Como isto funciona ([fonte][1]): Internamente, ele chama as OS APIs para obter o nome do SO como definido pelo SO. Isto pode obviamente mudar de versão para versão, então é melhor não usar diretamente. Veja [aqui][2] para vários valores específicos de SO.

**Método 2***

>>> import os
>>> os.name
'nt'  # for Linux and Mac it prints 'posix'

Como isto funciona ([fonte][3]): Internamente ele verifica se python tem módulos específicos de SO chamados posix ou nt. Se você quiser importar esses módulos e chamar métodos sobre ele, isso funciona muito bem. Note que não há diferenciação entre Linux ou OSX.

**Método 3***

>>> import platform
>>> platform.system()
'Windows' # for Linux it prints 'Linux', Mac it prints `'Darwin'

Como isto funciona ([fonte][4]): Internamente irá eventualmente chamar as APIs internas do SO, obter nomes específicos da versão do SO como 'win32' ou 'win16' ou 'linux1' e depois normalizar para nomes mais genéricos como 'Windows' ou 'Linux' ou 'Darwin' aplicando várias heurísticas. Esta é a melhor maneira portátil de obter um nome de SO normalizado.

**Sumário***

  • Se você quiser verificar se o SO é Windows ou Linux ou OSX então a maneira mais confiável é platform.system().
  • Se você quiser fazer chamadas específicas para o SO, mas através dos módulos Python embutidos posix ou nt, então use os.name.
  • Se você quiser obter o nome do SO bruto como fornecido pelo próprio SO, então utilize sys.platform.

[1]: https://github.com/python/cpython/blob/b82e17e626f7b1cd98aada0b1ebb65cb9f8fb184/Python/sysmodule.c#L1478 [2]: https://stackoverflow.com/a/13874620/207661 [3]: https://github.com/python/cpython/blob/3.7/Lib/os.py#L48 [4]: https://github.com/python/cpython/blob/3.7/Lib/platform.py#L949

Comentários (0)

Verifique os testes disponíveis com a plataforma do módulo e imprima a resposta para o seu sistema:

import platform

print dir(platform)

for x in dir(platform):
    if x[0].isalnum():
        try:
            result = getattr(platform, x)()
            print "platform."+x+": "+result
        except TypeError:
            continue
Comentários (0)

Você também pode usar apenas o módulo de plataforma sem importar o módulo para obter todas as informações.

>>> import platform
>>> platform.os.name
'posix'
>>> platform.uname()
('Darwin', 'mainframe.local', '15.3.0', 'Darwin Kernel Version 15.3.0: Thu Dec 10 18:40:58 PST 2015; root:xnu-3248.30.4~1/RELEASE_X86_64', 'x86_64', 'i386')

Um layout agradável e arrumado para fins de relatório pode ser conseguido usando esta linha:

for i in zip(['system','node','release','version','machine','processor'],platform.uname()):print i[0],':',i[1]

Isso dá esta saída:

system : Darwin
node : mainframe.local
release : 15.3.0
version : Darwin Kernel Version 15.3.0: Thu Dec 10 18:40:58 PST 2015; root:xnu-3248.30.4~1/RELEASE_X86_64
machine : x86_64
processor : i386

O que está faltando normalmente é a versão do sistema operacional, mas você deve saber se você está executando windows, linux ou mac uma forma indipendente de plataforma é usar este teste:

In []: for i in [platform.linux_distribution(),platform.mac_ver(),platform.win32_ver()]:
   ....:     if i[0]:
   ....:         print 'Version: ',i[0]
Comentários (0)

Esta solução funciona tanto para a "python" como para a "jython".

módulo os_identify.py:

import platform
import os

# This module contains functions to determine the basic type of
# OS we are running on.
# Contrary to the functions in the `os` and `platform` modules,
# these allow to identify the actual basic OS,
# no matter whether running on the `python` or `jython` interpreter.

def is_linux():
    try:
        platform.linux_distribution()
        return True
    except:
        return False

def is_windows():
    try:
        platform.win32_ver()
        return True
    except:
        return False

def is_mac():
    try:
        platform.mac_ver()
        return True
    except:
        return False

def name():
    if is_linux():
        return "Linux"
    elif is_windows():
        return "Windows"
    elif is_mac():
        return "Mac"
    else:
        return "" 

Use assim:

import os_identify

print "My OS: " + os_identify.name()
Comentários (0)