當前位置: 首頁>>代碼示例>>Python>>正文


Python platform.dist方法代碼示例

本文整理匯總了Python中platform.dist方法的典型用法代碼示例。如果您正苦於以下問題:Python platform.dist方法的具體用法?Python platform.dist怎麽用?Python platform.dist使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在platform的用法示例。


在下文中一共展示了platform.dist方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: parseDefaults

# 需要導入模塊: import platform [as 別名]
# 或者: from platform import dist [as 別名]
def parseDefaults(disable, defaultsGetter, log):
  defaultsMeta, defaultsBody = defaultsGetter()
  # Defaults are actually special packages. They can override metadata
  # of any other package and they can disable other packages. For
  # example they could decide to switch from ROOT 5 to ROOT 6 and they
  # could disable alien for O2. For this reason we need to parse their
  # metadata early and extract the override and disable data.
  defaultsDisable = asList(defaultsMeta.get("disable", []))
  for x in defaultsDisable:
    log("Package %s has been disabled by current default." % x)
  disable.extend(defaultsDisable)
  if type(defaultsMeta.get("overrides", OrderedDict())) != OrderedDict:
    return ("overrides should be a dictionary", None, None)
  overrides, taps = OrderedDict(), {}
  commonEnv = {"env": defaultsMeta["env"]} if "env" in defaultsMeta else {}
  overrides["defaults-release"] = commonEnv
  for k, v in defaultsMeta.get("overrides", {}).items():
    f = k.split("@", 1)[0].lower()
    if "@" in k:
      taps[f] = "dist:"+k
    overrides[f] = dict(**(v or {}))
  return (None, overrides, taps) 
開發者ID:alisw,項目名稱:alibuild,代碼行數:24,代碼來源:utilities.py

示例2: test_linux_distribution_encoding

# 需要導入模塊: import platform [as 別名]
# 或者: from platform import dist [as 別名]
def test_linux_distribution_encoding(self):
        # Issue #17429
        with tempfile.TemporaryDirectory() as tempdir:
            filename = os.path.join(tempdir, 'fedora-release')
            with open(filename, 'w', encoding='utf-8') as f:
                f.write('Fedora release 19 (Schr\xf6dinger\u2019s Cat)\n')

            with mock.patch('platform._UNIXCONFDIR', tempdir):
                with warnings.catch_warnings():
                    warnings.filterwarnings(
                        'ignore',
                        'dist\(\) and linux_distribution\(\) '
                        'functions are deprecated .*',
                        PendingDeprecationWarning,
                    )
                    distname, version, distid = platform.linux_distribution()

                self.assertEqual(distname, 'Fedora')
            self.assertEqual(version, '19')
            self.assertEqual(distid, 'Schr\xf6dinger\u2019s Cat') 
開發者ID:Microvellum,項目名稱:Fluid-Designer,代碼行數:22,代碼來源:test_platform.py

示例3: checkproc

# 需要導入模塊: import platform [as 別名]
# 或者: from platform import dist [as 別名]
def checkproc(self):
        dist, ver, name = platform.dist()
        if dist == "Ubuntu":
            self.proc = 'docker.io -d'
        else:
            self.proc = 'docker -d'
        try:
            s = subprocess.Popen(["ps", "aux"], stdout=subprocess.PIPE)
            for prs in s.stdout:
                if re.search(self.proc, prs):
                    logger.info(
                        "Requested process: %s is running" % (self.proc))
                    return True
        except Exception as e:
            logger.debug(e)
            return False 
開發者ID:humblec,項目名稱:dockit,代碼行數:18,代碼來源:install.py

示例4: find_package_manager

# 需要導入模塊: import platform [as 別名]
# 或者: from platform import dist [as 別名]
def find_package_manager(operation):
    """
    Checks if the dist is debian based or centos based and assigns the package manager accordingly
    """
    global PackageManager
    global BundleFileName
    dist, ver = find_vm_distro(operation)

    dpkg_set = {"debian", "ubuntu"}
    rpm_set = {"oracle", "redhat", "centos", "red hat", "suse"}
    for dpkg_dist in dpkg_set:
        if dist.lower().startswith(dpkg_dist):
            PackageManager = "dpkg"
            BundleFileName = BundleFileNameDeb
            break

    for rpm_dist in rpm_set:
        if dist.lower().startswith(rpm_dist):
            PackageManager = "rpm"
            BundleFileName = BundleFileNameRpm
            break

    if PackageManager == "":
        log_and_exit(operation, UnsupportedOperatingSystem, "The OS has neither rpm nor dpkg" ) 
開發者ID:Azure,項目名稱:azure-linux-extensions,代碼行數:26,代碼來源:agent.py

示例5: find_vm_distro

# 需要導入模塊: import platform [as 別名]
# 或者: from platform import dist [as 別名]
def find_vm_distro(operation):
    """
    Finds the Linux Distribution this vm is running on. 
    """
    vm_dist = vm_id = vm_ver =  None
    try:
        vm_dist, vm_ver, vm_id = platform.linux_distribution()
    except AttributeError:
        vm_dist, vm_ver, vm_id = platform.dist()

    if not vm_dist and not vm_ver: # SLES 15 and others
        try:
            with open('/etc/os-release', 'r') as fp:
                for line in fp:
                    if line.startswith('ID='):
                        vm_dist = line.split('=')[1]
                        vm_dist = vm_dist.split('-')[0]
                        vm_dist = vm_dist.replace('\"', '').replace('\n', '')
                    elif line.startswith('VERSION_ID='):
                        vm_ver = line.split('=')[1]
                        vm_ver = vm_ver.split('.')[0]
                        vm_ver = vm_ver.replace('\"', '').replace('\n', '')
        except:
            log_and_exit(operation, UndeterminateOperatingSystem, 'Undeterminate operating system')
    return vm_dist, vm_ver 
開發者ID:Azure,項目名稱:azure-linux-extensions,代碼行數:27,代碼來源:agent.py

示例6: DistInfo

# 需要導入模塊: import platform [as 別名]
# 或者: from platform import dist [as 別名]
def DistInfo():
    if 'FreeBSD' in platform.system():
        release = re.sub('\-.*\Z', '', str(platform.release()))
        distinfo = ['FreeBSD', release]
        return distinfo
    if os.path.isfile('/etc/oracle-release'):
        release = re.sub('\-.*\Z', '', str(platform.release()))
        distinfo = ['Oracle', release]
        return distinfo
    if 'linux_distribution' in dir(platform):
        distinfo = list(platform.linux_distribution(full_distribution_name=0))
        # remove trailing whitespace in distro name
        distinfo[0] = distinfo[0].strip()
        return distinfo
    else:
        return platform.dist() 
開發者ID:Azure,項目名稱:azure-linux-extensions,代碼行數:18,代碼來源:__init__.py

示例7: DistInfo

# 需要導入模塊: import platform [as 別名]
# 或者: from platform import dist [as 別名]
def DistInfo(fullname=0):
    if 'FreeBSD' in platform.system():
        release = re.sub('\-.*\Z', '', str(platform.release()))
        distinfo = ['FreeBSD', release]
        return distinfo
    if os.path.isfile('/etc/oracle-release'):
        release = re.sub('\-.*\Z', '', str(platform.release()))
        distinfo = ['Oracle', release]
        return distinfo
    if 'linux_distribution' in dir(platform):
        distinfo = list(platform.linux_distribution(\
                        full_distribution_name=fullname))
        # remove trailing whitespace in distro name
        distinfo[0] = distinfo[0].strip()
        return distinfo
    else:
        return platform.dist() 
開發者ID:Azure,項目名稱:azure-linux-extensions,代碼行數:19,代碼來源:__init__.py

示例8: getRecipeReader

# 需要導入模塊: import platform [as 別名]
# 或者: from platform import dist [as 別名]
def getRecipeReader(url, dist=None):
  m = re.search(r'^dist:(.*)@([^@]+)$', url)
  if m and dist:
    return GitReader(url, dist)
  else:
    return FileReader(url)

# Read a recipe from a file 
開發者ID:alisw,項目名稱:alibuild,代碼行數:10,代碼來源:utilities.py

示例9: __call__

# 需要導入模塊: import platform [as 別名]
# 或者: from platform import dist [as 別名]
def __call__(self):
    m = re.search(r'^dist:(.*)@([^@]+)$', self.url)
    fn,gh = m.groups()
    err,d = getstatusoutput(format("GIT_DIR=%(dist)s/.git git show %(gh)s:%(fn)s.sh",
                                   dist=self.configDir, gh=gh, fn=fn.lower()))
    if err:
      raise RuntimeError(format("Cannot read recipe %(fn)s from reference %(gh)s.\n" +
                                "Make sure you run first (this will not alter your recipes):\n" +
                                "  cd %(dist)s && git remote update -p && git fetch --tags",
                                dist=self.configDir, gh=gh, fn=fn))
    return d 
開發者ID:alisw,項目名稱:alibuild,代碼行數:13,代碼來源:utilities.py

示例10: get_os

# 需要導入模塊: import platform [as 別名]
# 或者: from platform import dist [as 別名]
def get_os():
    if platform.system() == 'Windows':
        uname = platform.uname()
        return '%s %s %s' % (uname[0], uname[2], uname[4])
    else:
        uname = platform.dist()
        return '%s %s %s %s' % (uname[0], uname[1], uname[2], platform.machine()) 
開發者ID:BennyThink,項目名稱:ServerSan,代碼行數:9,代碼來源:ss-agent.py

示例11: run

# 需要導入模塊: import platform [as 別名]
# 或者: from platform import dist [as 別名]
def run(self):
        if not self.distribution.dist_files:
            raise DistutilsOptionError("No dist file created in earlier command")
        for command, pyversion, filename in self.distribution.dist_files:
            self.upload_file(command, pyversion, filename) 
開發者ID:glmcdona,項目名稱:meddle,代碼行數:7,代碼來源:upload.py

示例12: test_dist

# 需要導入模塊: import platform [as 別名]
# 或者: from platform import dist [as 別名]
def test_dist(self):
        res = platform.dist() 
開發者ID:IronLanguages,項目名稱:ironpython2,代碼行數:4,代碼來源:test_platform.py

示例13: get_sysinfo

# 需要導入模塊: import platform [as 別名]
# 或者: from platform import dist [as 別名]
def get_sysinfo():
    info = {}
    
    #basic
    info["architecture"] = platform.architecture()[0]
    info["machine"] = platform.machine()
    info["node"] = platform.node()
    info["system"] = platform.system()
    
    #distro
    dist = platform.dist()
    info["dist"] = " ".join(x for x in dist)
    
    #cpuinfo
    with open("/proc/cpuinfo", "r") as f:
        cpuInfo = f.readlines()
    info["cpuinfo"] = [x.strip().split(":")[1] for x in cpuInfo if "model name" in x]

    #memory
    with open("/proc/meminfo", "r") as f:
        memInfo = f.readlines()
    info["memTotal"] = memInfo[0].strip()\
        .replace("MemTotal:        ", "").replace(" kB", "")
    info["memFree"] = memInfo[1].strip()\
        .replace("MemFree:          ", "").replace(" kB", "")

    #uptime
    with open("/proc/uptime") as f:
        uptime = f.read().split(" ")[0].strip()
    uptime = int(float(uptime))
    info["uptime"] = str(uptime)

    return info 
開發者ID:dawiddydlinski,項目名稱:web-rpi-fm,代碼行數:35,代碼來源:funcs.py

示例14: about

# 需要導入模塊: import platform [as 別名]
# 或者: from platform import dist [as 別名]
def about(application, appname=None, appversion=None):
    data = []
    if appname is not None:
        data.append("{}{}".format(appname,
            (" " + appversion) if appversion is not None else ""))
    python = platform.python_implementation()
    if python == "CPython":
        python = python[1:]
    data.append("{0} {1.major}.{1.minor}.{1.micro}".format(python,
            sys.version_info))
    data.append("Tk {}".format(application.tk.getvar(
            "tk_patchLevel")))
    system = platform.system()
    if system == "Linux":
        distro, version = platform.dist()[:2]
        if distro:
            system = "{}/{}".format(system, distro)
            if version:
                system += " " + version
    elif system == "Windows":
        version, service_pack = platform.win32_ver()[:2]
        if version:
            system = "{} {}".format(system, version)
            if service_pack:
                system += " (SP {})".format(service_pack)
    elif system == "Mac":
        version, info = platform.mac_ver()
        if version:
            system = "{} {}".format(system, version)
            if info:
                system += "." + info[0]
    return " • ".join(data) + "\n" + system + " • " + platform.machine()


# No shortcuts on Mac OS X 
開發者ID:lovexiaov,項目名稱:python-in-practice,代碼行數:37,代碼來源:__init__.py

示例15: create_package_from_setup_py

# 需要導入模塊: import platform [as 別名]
# 或者: from platform import dist [as 別名]
def create_package_from_setup_py(self, path_to_setup_py, custom_package_name):
        """
        Creates a package from Setup.py specified in the the given path
        :param path_to_setup_py:
        :return: Package Information: Contains package name, version and path
        """
        if os.path.isfile(path_to_setup_py):
            path_to_setup_py = os.path.abspath(path_to_setup_py)
            setup_py_directory = os.path.dirname(path_to_setup_py)
        elif os.path.isdir(path_to_setup_py):
            setup_py_directory = os.path.abspath(path_to_setup_py)
            path_to_setup_py = setup_py_directory + '/setup.py'
        else:
            raise Exception("Given path/file: " + path_to_setup_py + " doesn't exist")

        if not os.path.exists(path_to_setup_py):
            raise Exception("setup.py doesn't exist in the given path: " + path_to_setup_py)

        sandbox.run_setup(path_to_setup_py, ['sdist'])
        eggs = find_distributions(setup_py_directory)

        version = None
        for egg in eggs:
            if custom_package_name in egg.egg_name():
                version = egg.version

        if not version:
            raise Exception("{package_name} not found".format(package_name=custom_package_name))

        package_info = dict()
        package_info['path'] = setup_py_directory + "/dist/" + custom_package_name + "-" + version + ".tar.gz"
        package_info['version'] = version
        package_info['name'] = custom_package_name
        return package_info 
開發者ID:flipkart-incubator,項目名稱:Hunch,代碼行數:36,代碼來源:hunch_publisher.py


注:本文中的platform.dist方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。