मैं कमांड रिपॉजिटरी से सभी रिपॉजिटरी और पीपीए की सूची को एक इंस्टॉल स्क्रिप्ट में कैसे प्राप्त कर सकता हूं?


217

मुझे पता है कि मेरे सिस्टम पर स्थापित सभी पैकेजों को कैसे सूचीबद्ध किया जाए।

लेकिन मैं एक स्क्रिप्ट में सभी रिपॉजिटरी और पीपीए की सूची कैसे प्राप्त कर सकता हूं कि मैं कुंजी सहित रिपॉजिटरी सेटअप को दोहराने के लिए एक नई मशीन पर चला सकता हूं?

मुझे पता है कि मैं देख सकता हूँ /etc/apt/sources.listऔर /etc/apt/sources.list.d, लेकिन मैं एक ऐसी स्क्रिप्ट उत्पन्न करने का तरीका खोज रहा हूँ, जो apt-add-repositoryएक नई प्रणाली पर सभी कमांड्स को निष्पादित करे (जो कि सभी कुंजियों को प्राप्त कर रहा है)।

कोई विचार?

जवाबों:


106

आप सब कुछ के साथ दिखा सकते हैं:

grep ^ /etc/apt/sources.list /etc/apt/sources.list.d/*

13
क्या egrep -v '^#|^ *$' /etc/apt/sources.list /etc/apt/sources.list.d/*हटाने वाली लाइनों के बारे में टिप्पणी की गई और रिक्त लाइनों को हटा दिया गया?

3
आप के उपयोग के बारे में समझाएं सकता है ^के बाद grepमें grep ^ /etc/apt/sources.list /etc/apt/sources.list.d/*?

4
@ वासा 1 कैरेट ^ और डॉलर साइन $ $ मेटाचैटर्स हैं जो क्रमशः एक लाइन की शुरुआत और अंत में खाली स्ट्रिंग से मेल खाते हैं।
वुनॉक्स

4
मैं grep ^ [^ #] का उपयोग करता हूं ... - यह सभी टिप्पणी किए गए स्रोतों को ऑटो-छुपाता है
रॉस एकेन

12
यदि आप कुछ भी फ़िल्टर नहीं करने जा रहे हैं, तो क्या यह केवल रन करने के लिए सरल नहीं होगाcat /etc/apt/sources.list /etc/apt/sources.list.d/*
jbo5112

99

संकेत के लिए धन्यवाद। थोड़ी सी सफाई के साथ मुझे एक स्क्रिप्ट मिली जो PPA को सूचीबद्ध करती है, लेकिन किसी अन्य भंडार को नहीं:

#! /bin/sh 
# listppa Script to get all the PPA installed on a system ready to share for reininstall
for APT in `find /etc/apt/ -name \*.list`; do
    grep -o "^deb http://ppa.launchpad.net/[a-z0-9\-]\+/[a-z0-9\-]\+" $APT | while read ENTRY ; do
        USER=`echo $ENTRY | cut -d/ -f4`
        PPA=`echo $ENTRY | cut -d/ -f5`
        echo sudo apt-add-repository ppa:$USER/$PPA
    done
done

जब आप इसे अपने साथ बुलाते हैं तो listppa > installppa.shआपको एक स्क्रिप्ट मिलती है जिसे आप सभी PPA को पुनर्स्थापित करने के लिए एक नई मशीन पर कॉपी कर सकते हैं।

अगला स्टॉप: अन्य रिपॉजिटरी के लिए ऐसा करें:

#! /bin/sh
# Script to get all the PPA installed on a system
for APT in `find /etc/apt/ -name \*.list`; do
    grep -Po "(?<=^deb\s).*?(?=#|$)" $APT | while read ENTRY ; do
        HOST=`echo $ENTRY | cut -d/ -f3`
        USER=`echo $ENTRY | cut -d/ -f4`
        PPA=`echo $ENTRY | cut -d/ -f5`
        #echo sudo apt-add-repository ppa:$USER/$PPA
        if [ "ppa.launchpad.net" = "$HOST" ]; then
            echo sudo apt-add-repository ppa:$USER/$PPA
        else
            echo sudo apt-add-repository \'${ENTRY}\'
        fi
    done
done

यह काम कर जाना चाहिए। मुझे सही regex का पता लगाने के लिए सुपरयुसर पर एक प्रश्न की आवश्यकता थी ।


1
अपने में grep -oउदाहरण के लिए, \` में [a-z0-9\-]नहीं कर रहा है कि तुम क्या उम्मीद करते हैं। यह वास्तव में शाब्दिक बैकलैश से मेल खाता है । जब आप सूची के प्रारंभ या अंत में हों, तो आपको भागने की आवश्यकता नहीं है ; वास्तव में, आप इससे बच नहीं सकते ! .. इस मामले में (शायद) समस्या का कारण नहीं होगा, क्योंकि आप (उम्मीद) प्रविष्टि में एक बैकस्लैश का सामना नहीं करेंगे । -[]\`deb
पीटर। 3

2
ध्यान दें कि PPA के नाम में डॉट्स हो सकते हैं, इसलिए मुझे लगता है कि आप अपना regexp बदलना चाहते हैंhttp://ppa.launchpad.net/[a-z0-9-]\+/[a-z0-9.-]\+
kynan

नहीं, आप [[:graph:]] इसके बजाय regex को बदलना चाहते हैं [a-z...blah.anything]क्योंकि यह किसी भी अल्फ़ान्यूमेरिक + विराम चिह्न वर्णों से मेल खाएगा - यही PPA नामों से बना है।
मीकलह

मुझे लगता है कि आपको debप्रत्येक रिपॉजिटरी लाइन की शुरुआत में शब्द शामिल करना चाहिए , अगर ppa:$USER/$PPAफॉर्म में नहीं दिया गया है।
जर्नो

@stwissel कोई विशेष कारण जिसे आपने खोजा और फिर grep? आप आसानी से एक ग्लोब कर सकते हैं जो शेल पार्स करता है और इसे ग्रीप तक पास करता है। grep -Po "(?<=^deb\s).*?(?=#|$)" /etc/apt/{sources.list,sources.list.d/*.list} | while read ENTRY ; do echo $ENTRY; doneध्यान दें कि जैसा कि यह लिखा गया है कि आपको फ़ाइल का नाम प्रत्येक प्रविष्टि से पता चलता है, इसलिए आपको परिणाम की शुरुआत से पहली कॉल करने के लिए ट्रिम करने की आवश्यकता होगी, लेकिन यह कटौती के साथ बहुत मुश्किल नहीं है। uniqयदि आप एक ही स्रोत के लिए एक से अधिक प्रविष्टियाँ नहीं चाहते (जैसे कि आपके पास Google Chrome Stable / Beta / Dev) है, तो आप इसे पास करना चाहते हैं।
ड्रैगन 88 --88

23

मुझे आश्चर्य है कि सभी सक्षम बाइनरी सॉफ़्टवेयर स्रोतों को एक साथ प्राप्त करने के लिए सबसे सरल लेकिन सबसे प्रभावी तरीका वे निर्दिष्ट हैं जो अभी तक पोस्ट नहीं किए गए हैं:

grep -r --include '*.list' '^deb ' /etc/apt/sources.list /etc/apt/sources.list.d/

सभी प्रोसेस्ड फाइलों से, यह शुरू होने वाली हर लाइन को प्रिंट करेगा deb। यह deb-srcस्रोत कोड रिपॉजिटरी को सक्षम करने के लिए टिप्पणियों के साथ-साथ लाइनों को भी शामिल करता है।

यह वास्तव में केवल उन सभी *.listफ़ाइलों को खोजता है apt, जिनके द्वारा पार्स किया जाएगा , लेकिन उदाहरण के *.list.saveलिए बैकअप के लिए उपयोग की जाने वाली कोई फ़ाइल या अवैध नामों से अन्य नहीं।


यदि आप सभी मामलों में केवल 99.9% में एक छोटा लेकिन सही आउटपुट चाहते हैं जो बहुत अधिक फ़ाइलों को खोज सकता है (जिसमें सभी /etc/apt/sources.list*फाइलें और निर्देशिकाएं शामिल हैं, न केवल /etc/apt/sources.listऔर `/etc/apt/sources.list.d/*), तो आप भी कर सकते हैं। इसे इस्तेमाल करो:

grep -r --include '*.list' '^deb ' /etc/apt/sources.list*

जब तक ऐसी फाइलें नहीं होंगी, जो वहां नहीं होनी चाहिए, आउटपुट समान होगा।


मेरी मशीन पर एक उदाहरण आउटपुट यह होगा:

/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily main restricted
/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-updates main restricted
/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily universe
/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-updates universe
/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily multiverse
/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-updates multiverse
/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-backports main restricted universe multiverse
/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-security main restricted
/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-security universe
/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-security multiverse
/etc/apt/sources.list:deb http://archive.canonical.com/ubuntu wily partner
/etc/apt/sources.list.d/maarten-fonville-ubuntu-ppa-wily.list:deb http://ppa.launchpad.net/maarten-fonville/ppa/ubuntu wily main
/etc/apt/sources.list.d/webupd8team-ubuntu-tor-browser-wily.list:deb http://ppa.launchpad.net/webupd8team/tor-browser/ubuntu wily main
/etc/apt/sources.list.d/fossfreedom-ubuntu-indicator-sysmonitor-wily.list:deb http://ppa.launchpad.net/fossfreedom/indicator-sysmonitor/ubuntu wily main
/etc/apt/sources.list.d/getdeb.list:deb http://archive.getdeb.net/ubuntu wily-getdeb apps

यदि आप प्रीटियर उत्पादन चाहते हैं, तो इसे इसके माध्यम से पाइप करें sed:

grep -r --include '*.list' '^deb ' /etc/apt/ | sed -re 's/^\/etc\/apt\/sources\.list((\.d\/)?|(:)?)//' -e 's/(.*\.list):/\[\1\] /' -e 's/deb http:\/\/ppa.launchpad.net\/(.*?)\/ubuntu .*/ppa:\1/'

और हम इसे देखेंगे:

deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily main restricted
deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-updates main restricted
deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily universe
deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-updates universe
deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily multiverse
deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-updates multiverse
deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-backports main restricted universe multiverse
deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-security main restricted
deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-security universe
deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-security multiverse
deb http://archive.canonical.com/ubuntu wily partner
[maarten-fonville-ubuntu-ppa-wily.list] ppa:maarten-fonville/ppa
[webupd8team-ubuntu-tor-browser-wily.list] ppa:webupd8team/tor-browser
[fossfreedom-ubuntu-indicator-sysmonitor-wily.list] ppa:fossfreedom/indicator-sysmonitor
[getdeb.list] deb http://archive.getdeb.net/ubuntu wily-getdeb apps

1
स्वीकृत उत्तर के आधार पर, ऐसा लगता है कि ओपी चाहता था कि पीपीए को ppa:<user>/<project>फॉर्म में दिखाया जाए ।
मूरू

प्रश्न वास्तव में एक स्क्रिप्ट उत्पन्न करने के लिए कहता है जो सभी रिपॉजिटरी को स्थापित / सक्षम करता है। लेकिन प्रश्न शीर्षक केवल उन्हें सूचीबद्ध करने के बारे में है। साथ ही दूसरा उच्चतम स्कोर उत्तर केवल उन्हें ही सूचीबद्ध करता है, लेकिन यह बहुत अधिक सूची देता है।
बाइट कमांडर

अच्छा लगा, लेकिन मैं पहले से ही परेशान था। : डी
मुरु

आप फ़ाइल नामों को छोड़ने के लिए grep के लिए `-h` विकल्प का उपयोग कर सकते हैं।
जारो

11

निम्न आदेश चलाएँ:

apt-cache policy | grep http | awk '{print $2 $3}' | sort -u

स्रोत


बायोनिक में इस तरह की लाइनें ' दर्पण . nic.funet.fi/ubuntubionic-security/main '
jarno

1
नोट: apt-cache policyआपके द्वारा चलाए जाने के बाद केवल रिपॉज दिखाई देगा apt-get update। यदि आपने अभी-अभी रेपो जोड़ा है add-apt-repository, तो यह apt-cache policyतब तक नहीं दिखाई देगा जब तक आप दौड़ते नहीं हैंapt-get update
समझदार

प्रति @wisbucky: sudo apt update > /dev/null 2>&1 && sudo apt-cache policy | grep http | awk '{print $2 $3}' | sort -uअच्छी तरह से काम करता है। gist.github.com/bmatthewshea/229da822f1f02157bff192a2e4a8ffd1
bshea

4

वर्तमान में अक्षम लोगों सहित सभी कॉन्फ़िगर किए गए सॉफ़्टवेयर स्रोतों (रिपॉजिटरी) को सूचीबद्ध करने के लिए मैं इस कमांड का उपयोग करता हूं :

cat /etc/apt/sources.list; for X in /etc/apt/sources.list.d/*; do echo; echo; echo "** $X:"; echo; cat $X; done

मैं इसे मुख्य रूप से समस्या निवारण के लिए उपयोग करता हूं; यह निश्चित रूप से स्क्रिप्ट में शामिल किया जा सकता है, लेकिन आप को सीमित करने के लिए कर सकते हैं /etc/apt/sources.list.d/*करने के लिए /etc/apt/sources.list.d/*.listताकि आप केवल वर्तमान में सक्षम हो सॉफ्टवेयर स्रोतों।


प्रतिक्रिया के लिए Thx। बिल्ली फाइलों को सूचीबद्ध करती है जैसे वे हैं, इसलिए मुझे स्क्रिप्ट बनाने के लिए इसे मैन्युअल रूप से संपादित करने की आवश्यकता होगी (जैसा कि प्रश्न में कहा गया है)। रिपॉजिटरी के साथ चुनौती: यदि आप सिर्फ / etc / apt से फाइल कॉपी करते हैं तो आपको रिपॉजिटरी कीज़ नहीं मिलती हैं। यही कारण है कि मैं एक स्क्रिप्ट चाहता हूं जो उन्हें हमारे लिए लाती है
11:12 पर

2

इसलिए, कुछ खुदाई करके, हमारे पास है AptPkg::Class

तो perlहम का उपयोग कर इस तरह से कुछ सरल कर सकते हैं ..

perl -MAptPkg::Cache -MData::Dumper -E'say Dumper [AptPkg::Cache->new->files()]' | less

यह हमें सभी AptPkg::Class::PkgFileपैकेजों की एक सूची देता है। आप शायद उसी के apt-add-repositoryसाथ कमांड उत्पन्न कर सकते हैं ।


2

https://repogen.simplylinux.ch/ आपको उबंटू के अपने संस्करण के लिए सभी पीपीए की एक सूची देगा। यहाँ स्रोत फ़ाइलों और कोई सैमसंग प्रिंटर ppa के बिना एक उत्पन्न सूची है:

#------------------------------------------------------------------------------#
#                            OFFICIAL UBUNTU REPOS                             #
#------------------------------------------------------------------------------#


###### Ubuntu Main Repos
deb http://us.archive.ubuntu.com/ubuntu/ yakkety main restricted universe multiverse 

###### Ubuntu Update Repos
deb http://us.archive.ubuntu.com/ubuntu/ yakkety-security main restricted universe multiverse 
deb http://us.archive.ubuntu.com/ubuntu/ yakkety-updates main restricted universe multiverse 
deb http://us.archive.ubuntu.com/ubuntu/ yakkety-proposed main restricted universe multiverse 
deb http://us.archive.ubuntu.com/ubuntu/ yakkety-backports main restricted universe multiverse 

###### Ubuntu Partner Repo
deb http://archive.canonical.com/ubuntu yakkety partner

#------------------------------------------------------------------------------#
#                           UNOFFICIAL UBUNTU REPOS                            #
#------------------------------------------------------------------------------#


###### 3rd Party Binary Repos

#### Flacon PPA - http://kde-apps.org/content/show.php?content=113388
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys F2A61FE5
deb http://ppa.launchpad.net/flacon/ppa/ubuntu yakkety main

#### Gimp PPA - https://launchpad.net/~otto-kesselgulasch/+archive/gimp
## Run this command: sudo apt-key adv --recv-keys --keyserver keyserver.ubuntu.com 614C4B38
deb http://ppa.launchpad.net/otto-kesselgulasch/gimp/ubuntu yakkety main

#### Google Chrome Browser - http://www.google.com/linuxrepositories/
## Run this command: wget -q https://dl.google.com/linux/linux_signing_key.pub -O- | sudo apt-key add -
deb [arch=amd64] http://dl.google.com/linux/chrome/deb/ stable main

#### Google Earth - http://www.google.com/linuxrepositories/
## Run this command: wget -q https://dl.google.com/linux/linux_signing_key.pub -O- | sudo apt-key add -
deb [arch=amd64] http://dl.google.com/linux/earth/deb/ stable main

#### Highly Explosive PPA - https://launchpad.net/~dhor/+archive/myway
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 93330B78
deb http://ppa.launchpad.net/dhor/myway/ubuntu yakkety main

#### JDownloader PPA - https://launchpad.net/~jd-team
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 6A68F637
deb http://ppa.launchpad.net/jd-team/jdownloader/ubuntu yakkety main

#### Lazarus - http://www.lazarus.freepascal.org/
## Run this command:  gpg --keyserver hkp://pgp.mit.edu:11371 --recv-keys 6A11800F  && gpg --export --armor 0F7992B0  | sudo apt-key add -
deb http://www.hu.freepascal.org/lazarus/ lazarus-stable universe

#### LibreOffice PPA - http://www.documentfoundation.org/download/
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 1378B444
deb http://ppa.launchpad.net/libreoffice/ppa/ubuntu yakkety main

#### MEGA Sync Client - https://mega.co.nz/
deb http://mega.nz/linux/MEGAsync/xUbuntu_16.10/ ./

#### MKVToolnix - http://www.bunkus.org/videotools/mkvtoolnix/
## Run this command: wget -q http://www.bunkus.org/gpg-pub-moritzbunkus.txt -O- | sudo apt-key add -
deb http://www.bunkus.org/ubuntu/yakkety/ ./

#### Mozilla Daily Build Team PPA - http://edge.launchpad.net/~ubuntu-mozilla-daily/+archive/ppa
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys  247510BE
deb http://ppa.launchpad.net/ubuntu-mozilla-daily/ppa/ubuntu yakkety main

#### muCommander - http://www.mucommander.com/
## Run this command: sudo wget -O - http://apt.mucommander.com/apt.key | sudo apt-key add - 
deb http://apt.mucommander.com stable main non-free contrib  

#### Opera - http://www.opera.com/
## Run this command: sudo wget -O - http://deb.opera.com/archive.key | sudo apt-key add -
deb http://deb.opera.com/opera/ stable non-free

#### Oracle Java (JDK) Installer PPA - http://www.webupd8.org/2012/01/install-oracle-java-jdk-7-in-ubuntu-via.html
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys EEA14886
deb http://ppa.launchpad.net/webupd8team/java/ubuntu yakkety main

#### PlayDeb - http://www.playdeb.net/
## Run this command: wget -O- http://archive.getdeb.net/getdeb-archive.key | sudo apt-key add -
deb http://archive.getdeb.net/ubuntu yakkety-getdeb games

#### SABnzbd PPA - http://sabnzbd.org/
## Run this command:  sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 4BB9F05F
deb http://ppa.launchpad.net/jcfp/ppa/ubuntu yakkety main

#### SimpleScreenRecorder PPA - http://www.maartenbaert.be/simplescreenrecorder/
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 283EC8CD
deb http://ppa.launchpad.net/maarten-baert/simplescreenrecorder/ubuntu yakkety main

#### Steam for Linux - http://store.steampowered.com/about/
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys F24AEA9FB05498B7
deb [arch=i386] http://repo.steampowered.com/steam/ precise steam

#### Syncthing - https://syncthing.net/
## Run this command: curl -s https://syncthing.net/release-key.txt | sudo apt-key add -
deb http://apt.syncthing.net/ syncthing release

#### Tor: anonymity online - https://www.torproject.org
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 886DDD89
deb http://deb.torproject.org/torproject.org yakkety main

#### Unsettings PPA - http://www.florian-diesch.de/software/unsettings/
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 0FEB6DD9
deb http://ppa.launchpad.net/diesch/testing/ubuntu yakkety main

#### VirtualBox - http://www.virtualbox.org
## Run this command: wget -q http://download.virtualbox.org/virtualbox/debian/oracle_vbox_2016.asc -O- | sudo apt-key add -
deb http://download.virtualbox.org/virtualbox/debian yakkety contrib

#### Webmin - http://www.webmin.com
## Run this command: wget http://www.webmin.com/jcameron-key.asc -O- | sudo apt-key add -
deb http://download.webmin.com/download/repository sarge contrib

#### WebUpd8 PPA - http://www.webupd8.org/
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 4C9D234C
deb http://ppa.launchpad.net/nilarimogard/webupd8/ubuntu yakkety main

#### Xorg Edgers PPA - https://launchpad.net/~xorg-edgers
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 8844C542  
deb http://ppa.launchpad.net/xorg-edgers/ppa/ubuntu yakkety main
here is a generated list without source files and no samsung printer ppa
#### Yuuguu - http://yuuguu.com
deb http://update.yuuguu.com/repositories/apt hardy multiverse

2

यहां मेरी स्क्रिप्ट " list-apt-repositories" है, जो " /etc/sources.list"और" /etc/sources.list.d/*.list" सभी रिपॉजिटरी को सूचीबद्ध करती है । आप --ppa-onlyकेवल पीपीए दिखा सकते हैं । पीपीए स्वचालित रूप से ppa:USER/REPOप्रारूप में बदल जाते हैं ।

संबंधित भागों में 5 लाइनें list_sourcesऔर list_ppaफ़ंक्शन हैं, बाकी इसे केवल एक आसान शेल स्क्रिप्ट में लपेटने के लिए बॉयलरप्लेट है।

list-apt-repositories:

#!/bin/sh

usage () {
  cat >&2 <<USAGE
$0 [--ppa-only]

Options:
  --ppa-only            only list PPAs
USAGE
  exit $1
}

list_sources () {
  grep -E '^deb\s' /etc/apt/sources.list /etc/apt/sources.list.d/*.list |\
    cut -f2- -d: |\
    cut -f2 -d' ' |\
    sed -re 's#http://ppa\.launchpad\.net/([^/]+)/([^/]+)(.*?)$#ppa:\1/\2#g'
}

list_ppa () {
  list_sources | grep '^ppa:'
}

generate=list_sources

while test -n "$1"
do
  case "$1" in
    -h|--help) usage 1;;
    --ppa-only) generate=list_ppa;;
    *)
      printf -- "Unknown argument '$1'\n" >&2
      usage 2
    ;;
  esac
  shift
done

$generate

और एक स्थापित स्क्रिप्ट बनाने के लिए, दूसरी स्क्रिप्ट में पाइप करें " make-apt-repository-install-script"। उत्पन्न स्क्रिप्ट गैर-संवादात्मक उपयोग (देखें ) के लिए -y/ --yesतर्क का समर्थन करती है add-apt-repository(1)

make-apt-repository-install-script:

#!/bin/sh

if test -n "$1"
then
  cat >&2 <<USAGE
Usage: $0 < PATH_TO_LIST_OF_REPOS
       list-apt-repositories [--ppa-only] | $0

No options recognized.

Reads list of repositories from stdin and generates a script to install them
using \`add-apt-repository(1)\`. The script is printed to stdout.

The generated script supports an optional
\`-y\` or \`--yes\` argument which causes the \`add-apt-repository\` commands
to be run with the \`--yes\` flag.
USAGE
  exit 1
fi

cat <<INSTALL_SCRIPT
#!/bin/sh
y=
case "\$1" in
  -y|--yes) y=\$1;;
  '') y=;;
  *)
    printf '%s\n' "Unknown option '\$1'" "Usage: \$0 [{-y|--yes}]" >&2
    exit 1
  ;;
esac
INSTALL_SCRIPT

xargs -d'\n' printf "add-apt-repository \$y '%s'\n"

फिर से, महत्वपूर्ण हिस्सा xargsअंतिम पंक्ति पर कमांड है, बाकी बॉयलरप्लेट है।


1

इसे जोड़ने के लिए ppa.launchpad.net लाइनों को ppa के रूप में जोड़ें: $ USER / $ PPA। * .List फ़ाइलों से उनकी पूर्ण पंक्ति के साथ अन्य रिपॉजिटरी जोड़ें। कोई द्वैत रेखाएं नहीं।

#! / Bin / bash
# मेरा / बिन / mk_repositories_restore_script
mkdir -p ~ / bin 
एक्स = ~ / bin / restore_repositories
इको \ # \ /! / बिन / बैश> $ x
chmod u + x $ x
(
 $ में APT के लिए (खोजें / etc / apt / -name \ *। सूची)
    करो sed -n -e '/ ^ deb / {
     /ppa\.launchpad/s/\(.my\/\/d.co/dc/dw/dw/dw/dw/dw/dw/dw/dw/dw/pwp-p-p-p-pos-p-p-pos-p-pos-p-pos-p-pos-p-pos-p-pos-p-pos-p-pos-p-pos-p-pos-p-pos-p-pos-p-pos-p-pos-p-pos-p-pos-p-pos-p-p- जोड़-जोड़ कर करें : \ 2 / p;
     /ppa\.launchpad/ .s / \ (डिबेट [\ t] * \ _) (*। * $ \) / sudo apt-add-repository \ 2 / p;
    } '$ APT
 किया हुआ
) | सॉर्ट | यूनीक | टी-ए ~ / बिन / रिस्टोर_सेप्टिटोरीज़

0

धन्यवाद BobDodds!
अगर किसी को दिलचस्पी होगी, तो मैंने आपके कोड को थोड़ा अपडेट किया है (आशा है कि आपको कोई आपत्ति नहीं है) ..
यह स्क्रिप्ट केवल उपयोगकर्ता द्वारा जोड़े गए पीपीए (/etc/apt/source.list.d) को टाइप करेगी।

    #!/bin/bash
    # My ~/bin/mk_repositories_restore_script
    mkdir -p ~/bin
    x=~/bin/restore_repositories
    echo \#\!/bin/bash > $x
    chmod u+x $x
    (
    for APT in $( find /etc/apt/ -name \*.list )
    do sed -n -e '/^deb /{
          /ppa\.launchpad/s/\(.*\/\/[^\/]*.\)\([^ \t]*\)\(.*\/ubuntu.*$\)/ppa:\2/p;                                                                                                                                                                                       
        }' $APT
    done
    ) | sort | uniq | tee -a ~/bin/restore_repositories

0
sed -r -e '/^deb /!d' -e 's/^([^#]*).*/\1/' -e 's/deb http:\/\/ppa.launchpad.net\/(.+)\/ubuntu .*/ppa:\1/' -e "s/.*/sudo add-apt-repository '&'/" /etc/apt/sources.list /etc/apt/sources.list.d/*

हालाँकि, संभावित स्रोत रिपॉजिटरी (डीब-src) को सक्षम करने के लिए कमांड उत्पन्न नहीं करता है।


-1

इंस्टॉल करें I ppa-purge

apt install ppa-purge

तो टैब पूरा करके ppa सूची प्राप्त करें ...

ppa-purge -o( Tabकुंजी दो बार मारा )


2
यह थोड़े पीछे की ओर है। आप कैसे सुझाव देते हैं कि ओपी भंडारण या प्रसंस्करण के लिए शेल पूर्ण उत्पादन इकट्ठा करता है? इसके अलावा, इसके मैनुअल पेज के अनुसार ppa-purgeकोई -oध्वज नहीं है । -1
डेविड फोस्टरस्टर
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.