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


Python apt.Cache方法代碼示例

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


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

示例1: IsFFMPEG

# 需要導入模塊: import apt [as 別名]
# 或者: from apt import Cache [as 別名]
def IsFFMPEG():
    ''' Chech if FFMPEG is present '''
    if windows:
        if not os.path.isdir(ffmpegConf):
            return False
        if not os.path.isfile(os.path.join(ffmpegConf, 'ffmpeg.exe')):
            return False
    else:
        cache = apt.Cache()
        cache.open()
        try:
            return cache["ffmpeg"].is_installed
        except Exception:
            # does not exist
            return False
    return True 
開發者ID:All4Gis,項目名稱:QGISFMV,代碼行數:18,代碼來源:QgsFmvInstaller.py

示例2: detect_installation

# 需要導入模塊: import apt [as 別名]
# 或者: from apt import Cache [as 別名]
def detect_installation():
    if is_debian():  # For apt-based distros.
        import apt
        cache = apt.Cache()
        if 'wott-agent' in cache and __file__ in cache['wott-agent'].installed_files:
            return Installation.DEB
    elif is_amazon_linux2():  # For Amazon Linux 2.
        import rpm
        ts = rpm.ts()
        package_iterator = ts.dbMatch('name', 'python3-wott-agent')
        if package_iterator.count() > 0:
            package_header = next(package_iterator)
            if __file__.encode() in package_header[rpm.RPMTAG_FILENAMES]:
                return Installation.RPM
    # Other.
    from agent import __version__
    if isinstance(__version__, pkg_resources.Distribution):
        return Installation.PYTHON_PACKAGE
    return Installation.NONE 
開發者ID:WoTTsecurity,項目名稱:agent,代碼行數:21,代碼來源:os_helper.py

示例3: IsLavFilters

# 需要導入模塊: import apt [as 別名]
# 或者: from apt import Cache [as 別名]
def IsLavFilters():
    ''' Check if LavFilters is present '''
    if windows:
        software_list = WinSoftwareInstalled(winreg.HKEY_LOCAL_MACHINE, winreg.KEY_WOW64_32KEY) + WinSoftwareInstalled(winreg.HKEY_LOCAL_MACHINE, winreg.KEY_WOW64_64KEY) + WinSoftwareInstalled(winreg.HKEY_CURRENT_USER, 0)
        if not any('LAV Filters' in software['name'] for software in software_list):
            # does not exist
            return False
    else:
        cache = apt.Cache()
        cache.open()
        try:
            #print("lav filters")
            return cache["gst123"].is_installed
        except Exception:
            # does not exist
            return False
    return True 
開發者ID:All4Gis,項目名稱:QGISFMV,代碼行數:19,代碼來源:QgsFmvInstaller.py

示例4: identify_screensaver

# 需要導入模塊: import apt [as 別名]
# 或者: from apt import Cache [as 別名]
def identify_screensaver():
    cache = apt.Cache()
    logging.debug('Getting apt cache.')

    logging.debug('Checking if supported screensaver packages are installed.')
    if cache['xscreensaver'].is_installed and cache['gnome-screensaver'].is_installed:
        logging.debug('xscreensaver and gnome-screensaver installed. User must specify which package to monitor.')
        print("XScreenSaver and gnome-screensaver detected. Please select active screensaver in the settings file "
              "before proceeding.")
        sys.exit(403)
    if cache['xscreensaver'].is_installed:
        logging.debug('\txscreensaver installed.')
        return 'xscreensaver'
    elif cache['gnome-screensaver'].is_installed:
        logging.debug('\tgnome-screensaver installed.')
        return 'gnome-screensaver'
    else:
        print('Unable to run application, screensaver supported?')
        logging.critical('Aborting... Unable to run application, screensaver not supported.')
        sys.exit(402) 
開發者ID:errbufferoverfl,項目名稱:usb-canary,代碼行數:22,代碼來源:helpers.py

示例5: get_latest_same_kernel_deb

# 需要導入模塊: import apt [as 別名]
# 或者: from apt import Cache [as 別名]
def get_latest_same_kernel_deb(name_part0, name_part2):
    """
    Return the latest version of a deb package for given name parts.
    """
    import apt
    search_pattern = re.compile(name_part0 + r'(\d+)' + name_part2)

    class KernelFilter(apt.cache.Filter):
        """Filter class for checking for matching with a RE search pattern."""
        def apply(self, pkg):
            return pkg.is_installed and search_pattern.match(pkg.name)

    cache = apt.cache.FilteredCache(apt.Cache())
    cache.set_filter(KernelFilter())
    return sorted([(int(search_pattern.match(deb.name).group(1)), deb) for deb in cache],
                  reverse=True)[0][1] 
開發者ID:WoTTsecurity,項目名稱:agent,代碼行數:18,代碼來源:os_helper.py

示例6: get_updates

# 需要導入模塊: import apt [as 別名]
# 或者: from apt import Cache [as 別名]
def get_updates():
    cache = apt.Cache()
    cache.open(None)
    cache.upgrade()
    return str(cache.get_changes().__len__()) 
開發者ID:Sennevds,項目名稱:system_sensors,代碼行數:7,代碼來源:system_sensors.py

示例7: show_autoremovable_pkgs

# 需要導入模塊: import apt [as 別名]
# 或者: from apt import Cache [as 別名]
def show_autoremovable_pkgs():
    """List all the kernel related packages available for autoremoval.
    """
    packages = {}
    ver_max_len = 0
    try:
        apt_cache = apt.Cache()
    except SystemError:
        logger.error("Unable to obtain the cache!")
        sys.exit(1)
    for pkg_name in apt_cache.keys():
        pkg = apt_cache[pkg_name]
        if (pkg.is_installed and pkg.is_auto_removable) and re.match(
            r"^linux-(image|(\w+-)?headers)-.*$", pkg_name
        ):
            packages[pkg_name] = pkg.installed.version
            if ver_max_len < len(pkg.installed.version):
                ver_max_len = len(pkg.installed.version)
    if packages:
        logger.info("List of kernel packages available for autoremoval:")
        logger.info(
            "{0:>{width}} {1:<{width}}".format(
                "Version", "Package", width=ver_max_len + 2
            )
        )
        for package in sorted(packages.keys()):
            logger.info(
                "{0:>{width}} {1:<{width}}".format(
                    packages[package], package, width=ver_max_len + 2
                )
            )
        logger.log(
            42,
            "kernel packages available for autoremoval: {0}".format(
                sorted(packages.keys())
            ),
        )
    else:
        logger.log(42, "No kernel packages available for autoremoval.") 
開發者ID:rackerlabs,項目名稱:kthresher,代碼行數:41,代碼來源:kthresher.py

示例8: __init__

# 需要導入模塊: import apt [as 別名]
# 或者: from apt import Cache [as 別名]
def __init__(self, file_in, install):
        QtCore.QThread.__init__(self)
        self.cache = apt.Cache(None)
        self.cache.open()
        self.file_in = file_in
        self.install = install
        self.isDone = False
        self.logger = logging.getLogger(__name__)
        self.logger.setLevel(logging.DEBUG)
        handler = logging.FileHandler('/var/log/resetter/resetter.log')
        handler.setLevel(logging.DEBUG)
        formatter = logging.Formatter('%(asctime)s - %(name)s - %(funcName)s - %(levelname)s - %(message)s')
        handler.setFormatter(formatter)
        self.logger.addHandler(handler)
        self.resolver = apt.cache.ProblemResolver(self.cache)
        self.aprogress = UIAcquireProgress(False)
        self.thread1 = QtCore.QThread()
        self.aprogress.moveToThread(self.thread1)
        self.thread1.started.connect(lambda: self.aprogress.play(0.0, False, ""))
        self.aprogress.finished.connect(self.thread1.quit)

        self.thread2 = QtCore.QThread()
        self.iprogress = UIInstallProgress()
        self.iprogress.moveToThread(self.thread2)
        self.thread2.started.connect(lambda: self.iprogress.play(0.0, ""))
        self.iprogress.finished.connect(self.thread2.quit)
        self.broken_list = [] 
開發者ID:gaining,項目名稱:Resetter,代碼行數:29,代碼來源:InstallMissingDialog.py

示例9: __init__

# 需要導入模塊: import apt [as 別名]
# 或者: from apt import Cache [as 別名]
def __init__(self, file_in, install):
        QtCore.QThread.__init__(self)
        self.op_progress = None
        self.cache = apt.Cache(self.op_progress)
        self.cache.open()
        self.file_in = file_in
        self.isDone = False
        self.logger = logging.getLogger(__name__)
        self.logger.setLevel(logging.DEBUG)
        handler = logging.FileHandler('/var/log/resetter/resetter.log')
        handler.setLevel(logging.DEBUG)
        formatter = logging.Formatter('%(asctime)s - %(name)s - %(funcName)s - %(levelname)s - %(message)s')
        handler.setFormatter(formatter)
        self.logger.addHandler(handler)
        self.install = install

        self.aprogress = UIAcquireProgress(False)
        self.thread1 = QtCore.QThread()
        self.aprogress.moveToThread(self.thread1)
        self.thread1.started.connect(lambda: self.aprogress.play(0.0, False, ''))
        self.aprogress.finished.connect(self.thread1.quit)

        self.iprogress = UIInstallProgress()
        self.thread2 = QtCore.QThread()
        self.iprogress.moveToThread(self.thread2)
        self.thread2.started.connect(lambda: self.iprogress.play(0.0, ''))
        self.iprogress.finished.connect(self.thread2.quit)

        self.broken_list = [] 
開發者ID:gaining,項目名稱:Resetter,代碼行數:31,代碼來源:CustomApplyDialog.py

示例10: __init__

# 需要導入模塊: import apt [as 別名]
# 或者: from apt import Cache [as 別名]
def __init__(self, file_in, install):

        QtCore.QThread.__init__(self)
        self.cache = apt.Cache(None)
        self.cache.open()
        self.file_in = file_in
        self.isDone = False
        self.error_msg = QMessageBox()
        self.error_msg.setIcon(QMessageBox.Critical)
        self.error_msg.setWindowTitle("Error")
        self.logger = logging.getLogger(__name__)
        self.logger.setLevel(logging.DEBUG)
        handler = logging.FileHandler('/var/log/resetter/resetter.log')
        handler.setLevel(logging.DEBUG)
        formatter = logging.Formatter('%(asctime)s - %(name)s - %(funcName)s - %(levelname)s - %(message)s')
        handler.setFormatter(formatter)
        self.logger.addHandler(handler)
        self.install = install

        self.aprogress = UIAcquireProgress(False)
        self.thread1 = QtCore.QThread()
        self.aprogress.moveToThread(self.thread1)
        self.thread1.started.connect(lambda: self.aprogress.play(0.0, False, ""))
        self.aprogress.finished.connect(self.thread1.quit)

        self.iprogress = UIInstallProgress()
        self.thread2 = QtCore.QThread()
        self.iprogress.moveToThread(self.thread2)
        self.thread2.started.connect(lambda: self.iprogress.play(0.0, ""))
        self.iprogress.finished.connect(self.thread2.quit)

        self.broken_list = [] 
開發者ID:gaining,項目名稱:Resetter,代碼行數:34,代碼來源:ApplyDialog.py

示例11: update_apt_cache

# 需要導入模塊: import apt [as 別名]
# 或者: from apt import Cache [as 別名]
def update_apt_cache(self, init=False):
        '''if init is true, force to update, or it will update only once'''
        if init or not getattr(self, 'cache'):
            apt_pkg.init()
            self.cache = apt.Cache() 
開發者ID:gerardpuig,項目名稱:ubuntu-cleaner,代碼行數:7,代碼來源:package.py

示例12: get_kernel_deb_package

# 需要導入模塊: import apt [as 別名]
# 或者: from apt import Cache [as 別名]
def get_kernel_deb_package(boot_image_path):
    """
    Return a deb package instance for the currently running kernel.
    """
    import apt

    class FileFilter(apt.cache.Filter):
        def apply(self, pkg):
            return pkg.is_installed and boot_image_path in pkg.installed_files

    cache = apt.cache.FilteredCache(apt.Cache())
    cache.set_filter(FileFilter())
    kernel_debs = list(cache)
    if kernel_debs:
        return kernel_debs[0] 
開發者ID:WoTTsecurity,項目名稱:agent,代碼行數:17,代碼來源:os_helper.py

示例13: upgrade_packages

# 需要導入模塊: import apt [as 別名]
# 或者: from apt import Cache [as 別名]
def upgrade_packages(pkg_names):
    """
    Update all passed (as a list) OS packages.
    """
    unique_names = set(pkg_names)
    message = "The following packages will be upgraded:\n\t{}\nConfirm:"
    packages = []
    if is_debian():  # For apt-based distros.
        import apt
        cache = apt.cache.Cache()
        cache.update(apt.progress.text.AcquireProgress())
        cache.open()
        for pkg_name in unique_names:
            # Older versions of python3-apt don't provide full dict interface, namely .get().
            # The result of this expression will either be False or a apt.package.Package instance.
            pkg = pkg_name in cache and cache[pkg_name]
            if pkg and pkg.is_installed and pkg.is_upgradable:
                packages.append(pkg_name)
                pkg.mark_upgrade()
        if confirmation(message.format(', '.join(packages))):
            cache.commit()
    elif is_amazon_linux2():  # For Amazon Linux 2.
        import rpm
        from sh import yum  # pylint: disable=E0401
        ts = rpm.ts()

        # This will be a list like:
        # package.arch    version    repo
        list_updates = yum(['list', 'updates', '-q', '--color=no']).stdout

        # This will get a list of "package.arch"
        updates = [line.split(maxsplit=1)[0] for line in list_updates.splitlines()[1:]]
        for pkg_name in unique_names:
            package_iterator = ts.dbMatch('name', pkg_name)
            for package in package_iterator:
                # Package may be installed for multiple architectures. Get them all.
                fullname = b'.'.join((package[rpm.RPMTAG_NAME], package[rpm.RPMTAG_ARCH]))
                if fullname in updates:
                    packages.append(fullname.decode())
        if confirmation(message.format(', '.join(packages))):
            yum(['update', '-y'] + packages) 
開發者ID:WoTTsecurity,項目名稱:agent,代碼行數:43,代碼來源:os_helper.py

示例14: updated_cache

# 需要導入模塊: import apt [as 別名]
# 或者: from apt import Cache [as 別名]
def updated_cache(backup_ext, sources):
    with locked_sources_list():
        with sources_list_only(backup_ext, sources):
            cache = apt.Cache()
            cache.update()
            cache.open(None)
            yield cache 
開發者ID:Mirantis,項目名稱:ceph-lcm,代碼行數:9,代碼來源:apt.py

示例15: __init__

# 需要導入模塊: import apt [as 別名]
# 或者: from apt import Cache [as 別名]
def __init__(self, parent=None):
        super(EasyInstaller, self).__init__(parent)
        self.setWindowTitle("Easy install")
        self.list_view = QListView(self)
        self.list_view.setFixedWidth(380)
        self.EditText = QLineEdit()
        self.EditText.setPlaceholderText("Search for applications")
        self.model = QtGui.QStandardItemModel(self.list_view)
        self.setFixedSize(600, 350)
        self.font = QtGui.QFont()
        self.font.setBold(True)
        self.font2 = QtGui.QFont()
        self.font2.setBold(False)
        self.EditText = QLineEdit()
        self.EditText.setPlaceholderText("Add apps to install")
        self.btnRemove = QPushButton()
        self.btnInstall = QPushButton()
        self.btnBrowse = QPushButton()
        self.btnBrowse.setFixedWidth(100)
        self.btnBrowse.clicked.connect(self.openBackup)
        self.btnBrowse.setText("Open Backup")
        self.btnRemove.setText("Remove From List")
        self.btnRemove.clicked.connect(self.removeItems)
        self.btnInstall.setText("Install Apps")
        self.btnInstall.clicked.connect(self.installPackages)
        self.btnadd = QPushButton(self)
        self.btnadd.setText("Add App")
        self.btnClose = QPushButton()
        self.btnClose.setText("Close")
        self.btnClose.clicked.connect(self.closeview)
        self.btnadd.clicked.connect(self.addItems)
        self.btnselect = QPushButton()
        self.btnselect.setText("Select All")
        self.btnselect.clicked.connect(self.selectAll)
        self.comboBox = QComboBox()
        self.comboBox.setVisible(False)
        self.comboBox.currentIndexChanged.connect(self.setText)
        miniLayout = QVBoxLayout()
        miniLayout.addWidget(self.EditText)
        miniLayout.addWidget(self.comboBox)
        horizontalLayout = QHBoxLayout()
        horizontalLayout.addLayout(miniLayout)
        horizontalLayout.addWidget(self.btnadd)
        horizontalLayout.addWidget(self.btnBrowse)
        horizontalLayout.setAlignment(QtCore.Qt.AlignRight)
        horizontalLayout2 = QHBoxLayout()
        horizontalLayout2.addWidget(self.btnRemove)
        horizontalLayout2.addWidget(self.btnselect)
        horizontalLayout2.addWidget(self.btnInstall)
        horizontalLayout2.addWidget(self.btnClose)
        verticalLayout = QVBoxLayout(self)
        verticalLayout.addLayout(horizontalLayout)
        verticalLayout.addWidget(self.list_view)
        verticalLayout.addLayout(horizontalLayout2)
        self.cache = apt.Cache()
        self.isWritten = False 
開發者ID:gaining,項目名稱:Resetter,代碼行數:58,代碼來源:EasyInstall.py


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