7

によって提供されたこのコードをチェックしてpython_aptいますが、少し古くなっているようです。

https://github.com/jolicloud/python-apt/blob/master/doc/examples/inst.py

ここで私がやろうとしているのは、commit()メソッドの進行状況を追跡することだけです。現在、とを呼び出しcommit()て渡すfprogressiprogress、コンソールで、内のすべてのパッケージpkg_listが正しくダウンロードされていることがわかります。この後、問題が発生しているようです。

dpkg_status_change()プログラムは実行を継続しますが、私が信じているようにトリガーされませんか?

複数のパッケージのインストールが成功したかどうかを知る方法がありませんか?

import apt 
from apt.progress.base import InstallProgress

    class InstallStatusUpdate(InstallProgress):

            def conffile(self, current, new):
                print "conffile prompt: %s %s" % (current, new)

            def processing(self, pkg, stage):
                print "Processing ", pkg, " stage: ", stage

            def error(self, pkg, errormsg):
                print "Package ", pkg, " error: ", errormsg

            def finish_update(self):
                print "Installation is complete"

            def status_change(self, pkg, percent, status):
                print "Package: ", pkg, " at ", percent, " -> ", status

            def dpkg_status_change(self, pkg, status):
                print "Package ", pkg, ", Status: ", status



    def install_updates(self, pkg_list):
            fprogress = apt.progress.TextFetchProgress()
            iprogress = InstallStatusUpdate()

            cache_tmp = apt.Cache()
            cache_tmp.update()
            cache_tmp.open(None)

            for pkg in pkg_list:
                try:
                    self.pkgname = cache_tmp[pkg.name]
                    if self.pkgname.is_installed and self.pkgname.is_upgradable:
                        self.pkgname.mark_upgrade()
                    else:
                        self.pkgname.mark_install()
                except Exception as e:
                    print e.message

            result = self.pkgname.commit(fprogress, iprogress)
            #Maybe i'm doing something wrong here but result always = None...
4

1 に答える 1

3

どうやら作業python_apt commit()は面倒subprocessで、すべてが終了するのを待って(そうあるべきであるように)、最後に出力を解析して、パッケージが実際にアップグレードされたことを確認するために使用することになりました。

_apt_update()を試みる前に、システムがオンラインであることを確認してから、にapt-get update渡されたパッケージのインストールを続行します。_apt_install().

 def _apt_update(self):
        import urllib2

        try:
            response = urllib2.urlopen('http://74.125.113.99', timeout=1)
            #We have internet access
            subprocess.Popen(['apt-get', 'update'])
            return True
        except urllib2.URLError as err: pass
        return False

 def _apt_install(self, pkg, update=True):
        upgraded = 0

        if update == True:
            self._apt_update()

        proc = subprocess.Popen(['apt-get', 'install', pkg, "-y"], stdout=subprocess.PIPE)
        for line in proc.stdout:
            if "upgraded" in line and "newly installed" in line and "to remove" in line:
                values = line.split(",")
                for pos in values:
                    key, value = pos.split(" ")
                    if value == "upgraded":
                        upgraded = int(key)
                    break

        print "Upgraded OK (", upgraded, ")"
        if upgraded > 0:
            return True
        else:
            return False
于 2013-02-13T06:36:30.450 に答える