লিনাক্স: গন্তব্য দির উপস্থিত না থাকলে অনুলিপি করুন এবং তৈরি করুন


348

আমি একটি কমান্ড চাই (বা সম্ভবত সিপি করার একটি বিকল্প) যা গন্তব্য ডিরেক্টরিটি উপস্থিত না থাকলে তৈরি করে।

উদাহরণ:

cp -? file /path/to/copy/file/to/is/very/deep/there


5
গৃহীত উত্তরটি ভুল (সিপির জন্য এমন বিকল্প রয়েছে)। পল হিপ্পের দ্বিতীয় উত্তর দেখুন।
রোনজ

1
@ রোনেজ, আমি সম্মত হই যে জিএনইউতে উল্লেখ করার মতো একটি বিকল্প রয়েছে cp(পল হিপ্প উত্তর দিয়েছিল) তবে ওপি অনুরোধের মতো সাধারণ নয়। এটি অনুলিপি a/foo/bar/fileকরতে পারে b/foo/bar/fileতবে এটি অনুলিপি fileকরতে পারে না b/foo/bar/file। (যেমন এটি কেবলমাত্র পিতামাত ডিরেক্টরি তৈরি করতে কাজ করে যা প্রথম ফাইলের ক্ষেত্রে ইতিমধ্যে বিদ্যমান ছিল তবে এটি নির্বিচারে ডিরেক্টরি তৈরি করতে পারে না)
সুডো বাশ

এটি সিপির জন্য একটি দুর্দান্ত বৈশিষ্ট্যের অনুরোধ বলে মনে হচ্ছে। অদূর ভবিষ্যতে আমরা কোনও কমান্ড লাইন সুইচ পেতে পারি?
আর্নাড

উত্তর:


328
mkdir -p "$d" && cp file "$d"

(এর মতো কোনও বিকল্প নেই cp)।


62
আমি মনে করি না যে আপনার এটির দরকার test -d: mkdir -pডিরেক্টরিটি ইতিমধ্যে উপস্থিত থাকলেও সফল হয়।
প্রাক্তন

উফ, ঠিক আছে। তবে, পরীক্ষাটি বাশ বিল্টিন হতে পারে (বিশেষত যদি [[-d "$ d"]] হিসাবে লেখা হয়) এবং
এমকিডির


7
@ হোলস, $dএকটি পরিবর্তনশীল যা সম্ভবত ডিরেক্টরিটিতে ডিরেক্টরি অন্তর্ভুক্ত থাকে। মানে, যদি আপনি এটির তিনবার পুনরাবৃত্তি করতে পারেন তবে আপনি প্রথমে এটি পরিবর্তনশীলকে নির্ধারণ করতে পারেন।
মাইকেল ক্রেলিন - হ্যাকার

237

নিম্নলিখিত দুটি ক্ষেত্রে যদি সত্য হয়:

  1. আপনি cp(এবং উদাহরণস্বরূপ, ম্যাক সংস্করণ) এর GNU সংস্করণ এবং ব্যবহার করছেন
  2. আপনি কিছু বিদ্যমান ডিরেক্টরি কাঠামো থেকে অনুলিপি করছেন এবং আপনার এটি পুনরায় তৈরি করা দরকার

তারপরে আপনি এটি --parentsপতাকা সহ করতে পারেন cp। তথ্য পৃষ্ঠা থেকে ( http://www.gnu.org/software/coreutils/manual/html_node/cp-invocation.html#cp- ইনভোকেশন বা এর সাথে info cpবা এর সাথে দেখা যাবে man cp):

--parents
     Form the name of each destination file by appending to the target
     directory a slash and the specified name of the source file.  The
     last argument given to `cp' must be the name of an existing
     directory.  For example, the command:

          cp --parents a/b/c existing_dir

     copies the file `a/b/c' to `existing_dir/a/b/c', creating any
     missing intermediate directories.

উদাহরণ:

/tmp $ mkdir foo
/tmp $ mkdir foo/foo
/tmp $ touch foo/foo/foo.txt
/tmp $ mkdir bar
/tmp $ cp --parents foo/foo/foo.txt bar
/tmp $ ls bar/foo/foo
foo.txt

4
এটি ম্যাক ওএস এক্সে কাজ করে না, সুতরাং আমার ধারণা এটি লিনাক্স নির্দিষ্ট।
Olt

7
আমি gnu- নির্দিষ্ট বলতে চাই। আপনার যদি থাকে তবে আপনি macportsকোর্টিলগুলি এবং এটি ইনস্টল করতে পারেন gcp
মাইকেল ক্রেলিন - হ্যাকার

16
ম্যান, লিনাক্সের সবকিছু আছে
জিগজি

19
আমার কাছে মনে হচ্ছে এটি কিছুটা আলাদা প্রশ্নের উত্তর, যদিও আমি যে উত্তরটি খুঁজছিলাম তা হ'ল (এবং সেজন্য আমি যেটিকে উত্থাপন করেছি)। আমি অনুমান করি এটিই সমাধানটি ধরে নিয়ে আপনি গন্তব্য অভিভাবক ডিরেক্টরিগুলি মূল পিতৃ ডিরেক্টরিগুলির মতোই হতে চান, সম্ভবত এটি ব্যবহারের ক্ষেত্রে এটি বেশিরভাগ লোক আগ্রহী
ডেভিড উইনিস্কি

7
এটি ধরে নিয়েছে ডিরেক্টরি 'বার' ইতিমধ্যে বিদ্যমান আছে, তবে মূল প্রশ্নটি বোঝায় যে গন্তব্য হিসাবে যখন সরবরাহ করা হয় এবং এটি ইতিমধ্যে বিদ্যমান না হয় তখন স্বয়ংক্রিয়ভাবে 'বার' কীভাবে তৈরি করা যায়। এর উত্তর সরবরাহ করেছেন @ মাইকেলক্রেলিন-হ্যাকার।
thdoan

69

সংক্ষিপ্ত উত্তর

অনুলিপি myfile.txtকরতে /foo/bar/myfile.txt, ব্যবহার করুন:

mkdir -p /foo/bar && cp myfile.txt $_

কিভাবে কাজ করে?

এর কয়েকটি উপাদান রয়েছে, তাই আমি ধাপে সমস্ত সিনট্যাক্স কভার করব।

Mkdir, ইউটিলিটি, POSIX মান উল্লেখিত , ডিরেক্টরি করে তোলে। -pযুক্তি, দস্তাবেজ অনুযায়ী, কারণ হবে mkdir, করতে

নিখোঁজ মধ্যবর্তী পথের কোনও উপাদান তৈরি করুন

যার অর্থ যখন কলিং mkdir -p /foo/bar, mkdir, তৈরি করবে /foo এবং /foo/bar যদি /fooনা ইতিমধ্যেই বিদ্যমান নয়। (ছাড়া -p, এটি পরিবর্তে একটি ত্রুটি নিক্ষেপ করবে।

&&তালিকা অপারেটর, এ নথিভুক্ত যেমন POSIX মান (অথবা ব্যাশ ম্যানুয়াল আপনি যদি চান), প্রভাব যে হয়েছে cp myfile.txt $_শুধুমাত্র যদি মৃত্যুদন্ড কার্যকর করা mkdir -p /foo/bar, executes সফলভাবে। এর মানে হল cpকমান্ড যদি চালানো চেষ্টা করবে না mkdirব্যর্থ অনেক কারণ এটা ব্যর্থ হতে পারে এক

পরিশেষে, $_আমরা দ্বিতীয় আর্গুমেন্ট হিসাবে যে পাস করি তা cpহ'ল একটি "বিশেষ প্যারামিটার" যা ভেরিয়েবলের মধ্যে সংরক্ষণ না করে দীর্ঘ যুক্তি (ফাইল পাথের মতো) পুনরাবৃত্তি করা এড়াতে সুবিধাজনক হতে পারে। প্রতি ব্যাশ ম্যানুয়াল , এটা:

পূর্ববর্তী কমান্ডের সর্বশেষ যুক্তিতে প্রসারিত হয়

এই ক্ষেত্রে, /foo/barআমরা যে পাস mkdir। সুতরাং cpকমান্ডটি প্রসারিত হয় cp myfile.txt /foo/bar, যা myfile.txtসদ্য নির্মিত /foo/barডিরেক্টরিতে অনুলিপি করে ।

লক্ষ্য করুন $_হয় না POSIX মান অংশ , তাই তাত্ত্বিকভাবে একটি ইউনিক্স বৈকল্পিক একটি শেল যে এই কনস্ট্রাক্ট সমর্থন করে না থাকতে পারে। তবে, আমি এমন কোনও আধুনিক শাঁস জানি না যা সমর্থন করে না $_; অবশ্যই বাশ, ড্যাশ এবং zsh সবই করেন।


একটি চূড়ান্ত নোট: এই উত্তরটির শুরুতে আমি যে আদেশটি দিয়েছি তাতে অনুমান করা হয় যে আপনার ডিরেক্টরি নামগুলির মধ্যে ফাঁকা স্থান নেই you're আপনি যদি ফাঁকা জায়গাগুলির সাথে নামগুলি লেনদেন করেন তবে আপনাকে সেগুলি উদ্ধৃত করতে হবে যাতে ভিন্ন শব্দগুলি mkdirবা বিভিন্ন আর্গুমেন্ট হিসাবে বিবেচিত হয় না cp। সুতরাং আপনার কমান্ড আসলে দেখতে হবে:

mkdir -p "/my directory/name with/spaces" && cp "my filename with spaces.txt" "$_"

16
অন্যদিকে: স্ট্যাক ওভারফ্লোতে বাশ বা ইউনিক্স শেল কমান্ড সম্পর্কে প্রশ্নের বিস্তারের অভাব নিয়ে আমি সাধারণত হতাশ হয়ে পড়েছি, যা আপনি ইতিমধ্যে ইউনিক্স উইজার্ড না হলে প্রায়শই একটি জটিল এবং অত্যন্ত ঘন ওয়ান-লাইনার আনপিক করা শক্ত করে তোলে। আমি এখানে বিপরীত চরমের দিকে যাওয়ার চেষ্টা করেছি এবং উভয়ই সিনট্যাক্সের প্রতিটি বিবরণ ব্যাখ্যা করেছি এবং এই জিনিসগুলি কীভাবে কাজ করে তার ডকুমেন্টেশন সন্ধানের জন্য উপযুক্ত জায়গাগুলির লিঙ্ক করে। আমি আশা করি এটি কমপক্ষে কিছু লোককে সহায়তা করবে। এছাড়াও, যেখানে creditণ দেওয়া হয়েছে: আমি এই অনুলিপি প্রশ্নের উত্তর থেকে এই পদ্ধতির নিকটবর্তী হয়েছি: stackoverflow.com/a/14085147/1709587
মার্ক অ্যামেরি

আমি এর আগে কখনও দেখিনি। _ এটা কি কারণ নির্দেশ করছে? শেষ কমান্ডে ব্যবহৃত ফোল্ডারটি?
thebunnyrules

9
@ থেবুন্নিরুলস কিন্তু ... কিন্তু ... সেখানে "এটি কীভাবে কাজ করে?" আমার উত্তরের অংশটিতে আক্ষরিক অর্থে একাধিক অনুচ্ছেদ রয়েছে যা আপনি কেবল জিজ্ঞাসা করেছেন এমন প্রশ্নে উত্সর্গীকৃত। এটি অবহেলিত এবং প্রেমবিহীন মনে হয়। :(
মার্ক এ Amery

এর জন্যে দুঃখিত. তুমি একেবারেই সঠিক. আমি ইতিমধ্যে আপনার উত্তরের সমস্ত কিছুই জানতাম তাই আমি কেবল এটির মাধ্যমে স্ক্যান করলাম। আমার এটি আরও মনোযোগ সহকারে পড়া উচিত ছিল।
thebunnyrules

বাহ, আপনি এই উত্তরে সত্যই প্রচুর কাজ করেছিলেন ... তার জন্য ধন্যবাদ এটি সম্পর্কে জানতে পেরে ভাল লাগল: $ _। আমি এখন থেকে নিজেকে এটি বেশ খানিকটা ব্যবহার করতে দেখতে পাচ্ছি। পুরো প্রক্রিয়াটি স্বয়ংক্রিয় করতে এবং এই থ্রেডটিতে রাখার জন্য আমি একটি স্ক্রিপ্ট লিখেছিলাম। এটি একটি যেতে দিতে, হয়তো আপনি পছন্দ করবেন: stackoverflow.com/questions/1529946/...
thebunnyrules

39

যেমন একটি পুরানো প্রশ্ন, তবে আমি বিকল্প বিকল্প প্রস্তাব করতে পারেন।

আপনি installআপনার ফাইলটি অনুলিপি করতে এবং "ফ্লাইতে" গন্তব্য পথ তৈরি করতে প্রোগ্রামটি ব্যবহার করতে পারেন ।

install -D file /path/to/copy/file/to/is/very/deep/there/file

কিছু বিষয় বিবেচনা করার আছে, যদিও:

  1. আপনাকে গন্তব্য ফাইলের নামও নির্দিষ্ট করতে হবে , কেবল গন্তব্য পথ নয়
  2. গন্তব্য ফাইলটি কার্যকর হবে (কমপক্ষে, আমি আমার পরীক্ষাগুলি থেকে যতদূর দেখেছি)

-mগন্তব্য ফাইলটিতে অনুমতি সেট করার বিকল্প যুক্ত করে আপনি সহজেই # 2 টি সংশোধন করতে পারেন (উদাহরণস্বরূপ: নতুন ফাইল তৈরির মতো -m 664অনুমতি সহ গন্তব্য ফাইলটি তৈরি করবে )।rw-rw-r--touch


এবং আমি এখানে উত্তর দিয়ে অনুপ্রাণিত হয়েছি তার নির্লজ্জ লিঙ্ক is )


আমার ব্যবহারের জন্য সত্যই কার্যকর হয়নি তবে দুর্দান্ত কৌশল! আমি মনে রাখব।
thebunnyrules

নোট করুন যে এই কমান্ডটি 755( rwxr-xr-x) অনুমতি নিয়ে গন্তব্য ফাইলগুলি তৈরি করে যা সম্ভবত পছন্দসই নয়। আপনি -mস্যুইচ দিয়ে অন্য কিছু নির্দিষ্ট করতে পারেন, তবে আমি কেবল ফাইলের অনুমতি রাখার উপায় খুঁজে
পাইনি

19

শেল ফাংশন যা আপনি চান তা করেন, এটি "বারী" অনুলিপি বলছেন কারণ এটি ফাইলটি থাকার জন্য একটি গর্ত খনন করে:

bury_copy() { mkdir -p `dirname $2` && cp "$1" "$2"; }

1
dirname $2আপনারও খুব কাছাকাছি উদ্ধৃতি চিহ্ন থাকা উচিত
টার্নে কলমেন

4
@ কলমি, যথাযথ উদ্ধৃতি দেওয়ার জন্য আপনি $2যুক্তি হিসাবে উদ্ধৃত করতে চান dirname। লাইক mkdir -p "$(dirname "$2")"। এই উদ্ধৃতি ছাড়া $2cp); অনর্থক
হ্যাকার - মাইকেল Krelin

3
নোট করুন যে এই উত্তরটি ধরে নিয়েছে যে answer 2 ইতিমধ্যে লক্ষ্য নির্দেশিকা নয়, অন্যথায় আপনি কেবল "mkdir -p" $ 2 "এবং & সিপি" $ 1 "" $ 2 "ফাংশন বডি হিসাবে
চাইবেন

আমি মনে করি এটিতে একটি বাগ রয়েছে, যেমন @ ব্যবহারকারীর 4667257 পয়েন্ট রয়েছে। আমি মনে করি না এটি স্থিরযোগ্য, কারণ scenario 2 এই দৃশ্যে লক্ষ্য dir এবং টার্গেট ফাইলের মধ্যে অস্পষ্ট। আমি একটি বিকল্প উত্তর পোস্ট করেছি যা এটি সম্বোধন করে।
ধনী

@ ধনী, আমি একমত যে এটি স্থির নয়। নিম্নলিখিত ফাইল এবং ডিরেক্টরি উভয়ের জন্য ঠিক কাজ করে: mkdir -p dirname "$2"&& p; cp -r "$ 1" "$ 2"; নোট করুন যে ব্যাকটিকগুলি চারপাশে প্রদর্শিত dirname $2হবে না কারণ এসও তাদের কোড মার্কার হিসাবে পার্স করে।
ইয়ুরি

11

এটি করার একটি উপায় এখানে:

mkdir -p `dirname /path/to/copy/file/to/is/very/deep/there` \
   && cp -r file /path/to/copy/file/to/is/very/deep/there

dirnameআপনাকে গন্তব্য ডিরেক্টরি বা ফাইলের পিতামাতার দেওয়া হবে। mkdir -p ir dirname ... then তারপরে সেই ডিরেক্টরিটি তৈরি করবে তা নিশ্চিত করে আপনি যখন সিপি -আর কল করবেন তখন সঠিক বেস ডিরেক্টরিটি রয়েছে।

এই ওভার-প্যারেন্টগুলির সুবিধা হ'ল এটি সেই ক্ষেত্রে কাজ করে যেখানে গন্তব্য পথে সর্বশেষ উপাদানটি একটি ফাইলের নাম।

এবং এটি ওএস এক্সে কাজ করবে


6

install -D file -m 644 -t /path/to/copy/file/to/is/very/deep/there


1
আসলে, এটি মোটেও এক নয়। তার জন্য আপনাকে দুটিবার ফাইলের নামটি পাস করতে হবে (অতএব '-t' পতাকা) এবং এটি ফাইলটিতে এক্সিকিউট বিট সেট করে (অতএব '-ম' উদাহরণ)। তার শীর্ষস্থানীয় উত্তর হওয়া উচিত নয় , যেহেতু এটি আসলে প্রশ্নের উত্তর দেয় না - যেখানে আমার কাজটি করে।
স্পঞ্জম্যান

1
এটি একটি একক ফাইলের জন্য কাজ করে। কেবলমাত্র thereচূড়ান্ত ফাইল যা চূড়ান্ত উপ-ডিরেক্টরি নয় তা বিবেচনা করুন।
কাওয়ন্তুর

6

উপরের উত্তরগুলির জন্য আমার সমস্ত শ্রদ্ধার সাথে, আমি নিম্নলিখিত হিসাবে rsync ব্যবহার করতে পছন্দ করি:

$  rsync -a directory_name /path_where_to_inject_your_directory/

উদাহরণ:

$ rsync -a test /usr/local/lib/

আমি চেষ্টা করে দেখেছি এবং এই ফলাফলটি পেয়েছি: rsync -a ষাঁড় / কিছু / হুপ / টিআই / ডুপ / প্লুপ রেজাল্ট আরএসসিএনসি: এমকিডিআর "/ কিছু / হুপ / টিআই / ডুপ / প্লুপ" ব্যর্থ হয়েছে: এই জাতীয় কোনও ফাইল বা ডিরেক্টরি (2) আরএসএনসি ত্রুটি নেই : ফাইলের আইও-তে ত্রুটি (কোড 11) এ সিএনসি (675) [রিসিভার = 3.1.2]
thebunnyrules

@thebunnyrules আপনি pwd কমান্ডের সাহায্যে পাথটি পরীক্ষা করতে হবে (দেখুন: [লিঙ্ক] ( অ্যাক্সেস.ড্র্যাট / ডকুমেন্টেশন / en- ইউএস / রেডহ্যাট_এন্টারপ্রাইজ_লিনাক্স / ))) এবং এটি আপনার নির্দেশে সঠিকভাবে সন্নিবেশ করান
মার্কডাহান

যদি আমি আপনার পরামর্শটি সঠিকভাবে বুঝতে পারি তবে আপনি প্রস্তাব দিচ্ছেন যে উত্সের জন্য আমি একটি সম্পূর্ণ পথ নির্দিষ্ট করেছি যা ওরফে কেবলমাত্র ফাইলের নাম: ষাঁড়ের পরিবর্তে আমার আদেশে "$ (pwd) / ষাঁড়" ব্যবহার করুন? জিনিসটি হ'ল, ত্রুটিটি আরএসএনসিএন তৈরির সাথে গন্তব্যস্থল তৈরি করে, উত্স (ষাঁড়) নয়। আমার কাছে দেখে মনে হচ্ছে আরএসসিএনসি একটি সাধারণ এমকেডির ব্যবহার করে এবং এমকেডির-পি ব্যবহার করে না।
thebunnyrules

1
উপায় দ্বারা দুর্দান্ত ইউটিলিটি, আমি আমার স্ক্রিপ্টগুলিতে ব্যবহার শুরু করতে পারি। এটি সুপারিশ করার জন্য ধন্যবাদ।
thebunnyrules

1
rsync এর চেয়ে বেশি অনুমানযোগ্য cp। উদাহরণস্বরূপ, যদি আমি চাই cp /from/somedir /to-dirতবে সিপি /to-dirইতিমধ্যে বিদ্যমান থাকলে অন্যরকম আচরণ করে : যদি /to-dirউপস্থিত থাকে তবে cpতৈরি হবে /to-dir/some-dir, অন্যথায় কেবল সামগ্রীগুলি এতে /from/somedirস্থাপন করা হয় /to-dir। যাইহোক, rsyncযদি একই আচরণ করবে অর্থাত, /to-dir/some-dirহবে সবসময় তৈরি করা।
জোয়াক

5

কেবল পুনরায় শুরু করতে এবং এক লাইনে একটি সম্পূর্ণ কার্যক্ষম সমাধান দিতে। আপনি যদি নিজের ফাইলটির নাম পরিবর্তন করতে চান তবে সাবধান থাকুন, আপনাকে এমকেডিরকে একটি পরিষ্কার দির পাথ সরবরাহ করার একটি উপায় অন্তর্ভুক্ত করা উচিত। d fdst ফাইল বা dir হতে পারে। পরবর্তী কোডটি যে কোনও ক্ষেত্রে কাজ করা উচিত।

fsrc=/tmp/myfile.unk
fdst=/tmp/dir1/dir2/dir3/myfile.txt
mkdir -p $(dirname ${fdst}) && cp -p ${fsrc} ${fdst}

বা বাশ নির্দিষ্ট

fsrc=/tmp/myfile.unk
fdst=/tmp/dir1/dir2/dir3/myfile.txt
mkdir -p ${fdst%/*} && cp -p ${fsrc} ${fdst}

ধন্যবাদ! এই আমার প্রয়োজন ছিল। আমার ক্ষেত্রে আমি জানি না যে গন্তব্যটির ডিরেক্টরি রয়েছে কিনা এবং ডিরেক্টরিটি আছে কি না তাই এই কোডটি আমাকে
পিতামতী নির্দেশিকা

4

কেবল আপনার .bashrc এ নিম্নলিখিতগুলি যুক্ত করুন, আপনার প্রয়োজন হলে টুইট করুন। উবুন্টুতে কাজ করে।

mkcp() {
    test -d "$2" || mkdir -p "$2"
    cp -r "$1" "$2"
}

উদাহরণস্বরূপ, আপনি যদি গন্তব্য ডিরেক্টরি 'd' ব্যবহার করে 'পরীক্ষা' ফাইলটি অনুলিপি করতে চান,

mkcp test a/b/c/d

mkcp প্রথমে গন্তব্য ডিরেক্টরি উপস্থিত আছে কিনা তা যাচাই করবে, তা না হলে তৈরি করুন এবং উত্স ফাইল / ডিরেক্টরি অনুলিপি করুন।


অন্যরা যেমন অন্য উত্তরে মন্তব্য করেছে তেমন আপনাকে ডাকার আগে ডিরেক্টরি উপস্থিত থাকলে পরীক্ষা করার দরকার নেই mkdir -p। এটি ইতিমধ্যে বিদ্যমান থাকলেও এটি সফল হবে।
বোফোঁটেন


3

আমি সিপির জন্য একটি সমর্থন স্ক্রিপ্ট লিখেছিলাম, সিপি (নোট মূলধন) যা ঠিক এটি করার উদ্দেশ্যে তৈরি হয়েছিল। স্ক্রিপ্ট আপনার যে পথটি ফেলেছে তার ত্রুটিগুলি যাচাই করবে (শেষটি যা গন্তব্য এটি ব্যতীত) এবং যদি সবকিছু ঠিক থাকে তবে এটি অনুলিপি শুরু করার আগে গন্তব্য পথ তৈরি করার জন্য একটি mkdir -p পদক্ষেপ করবে। এই মুহুর্তে নিয়মিত সিপি ইউটিলিটিটি নিয়ে যায় এবং সিপি দিয়ে আপনি যে কোনও স্যুইচ ব্যবহার করেন (যেমন -r, -p, -rpL সরাসরি সিপিতে পাইপ পাইয়া যায়)। আপনি আমার স্ক্রিপ্টটি ব্যবহার করার আগে আপনার কয়েকটি জিনিস বুঝতে হবে।

  • সিপি --হেল্প করে এখানে সমস্ত তথ্য অ্যাক্সেস করা যায়। সিপি - হেল্প-সবগুলিতে সিপির সুইচগুলি অন্তর্ভুক্ত রয়েছে।
  • গন্তব্য পথটি খুঁজে না পাওয়া গেলে নিয়মিত সিপি অনুলিপিটি করে না। সিপি সহ টাইপসের জন্য আপনার কাছে এমন সুরক্ষা জাল নেই। আপনার গন্তব্য তৈরি করা হবে, সুতরাং আপনি যদি আপনার গন্তব্যটিকে / usr / share / আইকন বা / usr / শেয়ার / আইকন হিসাবে ভুল বানান করেন তবে এটিই তৈরি হবে going
  • নিয়মিত সিপি বিদ্যমান পথে এটির আচরণের মডেল করতে থাকে: সিপি / এ / বি / সি / ডি ডি বিদ্যমান কিনা তা পৃথক হবে। যদি ডি একটি বিদ্যমান ফোল্ডার হয় তবে সিপি / বি / সি / ডি / বি তৈরি করে এতে বি কপি করবে। D এর অস্তিত্ব না থাকলে, b কে c- এ অনুলিপি করে নতুন নামকরণ করা হবে। যদি ডি বিদ্যমান থাকে তবে একটি ফাইল এবং বি একটি ফাইল হয় তবে খ এর অনুলিপি দ্বারা এটি ওভাররাইট করা হবে। যদি সিটির অস্তিত্ব না থাকে, সিপি অনুলিপিটি করে না এবং প্রস্থান করে।

সিপিতে বিদ্যমান পাথ থেকে সংকেত নেওয়ার বিলাসিতা নেই, তাই এটির জন্য বেশ কয়েকটি দৃ firm় আচরণের নিদর্শন থাকতে হবে। সিপি ধরে নিয়েছে যে আপনি যে আইটেমটি অনুলিপি করছেন সেটি গন্তব্য পথে ফেলে দেওয়া হচ্ছে এবং এটি গন্তব্য নয় (ওরফে, উত্স ফাইল / ফোল্ডারের একটি নামকৃত অনুলিপি)। অর্থ:

  • "সিপি / এ / বি / সি / ডি" এর ফলাফল / সি / ডি / বি হবে যদি ডি ফোল্ডার হয়
  • "সিপি / এ / বি / সি / বি" এর ফলাফল / সি / বি / বি হবে যদি বি ইন / সি / বি একটি ফোল্ডার হয়।
  • যদি খ এবং ডি উভয়ই ফাইল হয়: সিপি / এ / বি / সি / ডি ফলাফল হবে / সি / ডি (যেখানে ডি বি এর অনুলিপি)। একই পরিস্থিতিতে সিপি / এ / বি / সি / বি এর জন্য একই।

এই ডিফল্ট সিপি আচরণটি "- নাম" স্যুইচ দিয়ে পরিবর্তন করা যেতে পারে। এই ক্ষেত্রে, এটি ধরে নেওয়া হয়

  • "সিপি - নাম / এ / বি / সি / ডি" বি কে / সি-তে অনুলিপি করছে এবং অনুলিপিটির নাম পরিবর্তন করে ডি।

কয়েকটি সমাপ্ত নোট: সিপির মতো সিপি একবারে একাধিক আইটেম অনুলিপি করতে পারে শেষ গন্তব্য হিসাবে ধরে নেওয়া শেষের পথে তালিকাভুক্ত। আপনি যতক্ষণ উদ্ধৃতি চিহ্ন ব্যবহার করেন ততক্ষণ স্পেস সহ পাথগুলিও পরিচালনা করতে পারে।

সিপি আপনাকে যে পাথগুলি রেখেছিল তা পরীক্ষা করবে এবং অনুলিপিটি করার আগে সেগুলি বিদ্যমান কিনা তা নিশ্চিত করবে। কঠোর মোডে (- স্ট্রাইক স্যুইচের মাধ্যমে উপলব্ধ), অনুলিপি করা সমস্ত ফাইল / ফোল্ডার অবশ্যই উপস্থিত রয়েছে বা কোনও অনুলিপি স্থান নেয় না। রিল্যাক্স মোডে (- রিলাক্সড) আপনার অনুলিপি করা আইটেমগুলির মধ্যে কমপক্ষে একটি উপস্থিত থাকলে অনুলিপি অবিরত থাকবে। রিলাক্স মোডটি ডিফল্ট, আপনি স্ক্রিপ্টের শুরুতে পরিবর্তনশীল ইজ_গৌজ সেট করে স্থায়ীভাবে স্যুইচগুলির মাধ্যমে বা স্থায়ীভাবে মোডটি পরিবর্তন করতে পারেন।

এটি কীভাবে ইনস্টল করবেন তা এখানে:

একটি রুটহীন টার্মিনালে, করুন:

sudo echo > /usr/bin/CP; sudo chmod +x /usr/bin/CP; sudo touch /usr/bin/CP
gedit admin:///usr/bin/CP 

জিডিট-এ, সিপি ইউটিলিটি পেস্ট করুন এবং সংরক্ষণ করুন:

#!/bin/bash
#Regular cp works with the assumption that the destination path exists and if it doesn't, it will verify that it's parent directory does.

#eg: cp /a/b /c/d will give /c/d/b if folder path /c/d already exists but will give /c/d (where d is renamed copy of b) if /c/d doesn't exists but /c does.

#CP works differently, provided that d in /c/d isn't an existing file, it assumes that you're copying item into a folder path called /c/d and will create it if it doesn't exist. so CP /a/b /c/d will always give /c/d/b unless d is an existing file. If you put the --rename switch, it will assume that you're copying into /c and renaming the singl item you're copying from b to d at the destination. Again, if /c doesn't exist, it will be created. So CP --rename /a/b /c/d will give a /c/d and if there already a folder called /c/d, contents of b will be merged into d. 

#cp+ $source $destination
#mkdir -p /foo/bar && cp myfile "$_"

err=0 # error count
i=0 #item counter, doesn't include destination (starts at 1, ex. item1, item2 etc)
m=0 #cp switch counter (starts at 1, switch 1, switch2, etc)
n=1 # argument counter (aka the arguments inputed into script, those include both switches and items, aka: $1 $2 $3 $4 $5)
count_s=0
count_i=0
easy_going=true #determines how you deal with bad pathes in your copy, true will allow copy to continue provided one of the items being copied exists, false will exit script for one bad path. this setting can also be changed via the custom switches: --strict and --not-strict
verbal="-v"


  help="===============================================================================\
    \n         CREATIVE COPY SCRIPT (CP) -- written by thebunnyrules\
    \n===============================================================================\n
    \n This script (CP, note capital letters) is intended to supplement \
    \n your system's regular cp command (note uncapped letters). \n
    \n Script's function is to check if the destination path exists \
    \n before starting the copy. If it doesn't it will be created.\n    
    \n To make this happen, CP assumes that the item you're copying is \
    \n being dropped in the destination path and is not the destination\
    \n itself (aka, a renamed copy of the source file/folder). Meaning:\n 
    \n * \"CP /a/b /c/d\" will result in /c/d/b \
    \n * even if you write \"CP /a/b /c/b\", CP will create the path /a/b, \
    \n   resulting in /c/b/b. \n
    \n Of course, if /c/b or /c/d are existing files and /a/b is also a\
    \n file, the existing destination file will simply be overwritten. \
    \n This behavior can be changed with the \"--rename\" switch. In this\
    \n case, it's assumed that \"CP --rename /a/b /c/d\" is copying b into /c  \
    \n and renaming the copy to d.\n
    \n===============================================================================\
    \n        CP specific help: Switches and their Usages \
    \n===============================================================================\n
    \
    \n  --rename\tSee above. Ignored if copying more than one item. \n
    \n  --quiet\tCP is verbose by default. This quiets it.\n
    \n  --strict\tIf one+ of your files was not found, CP exits if\
    \n\t\tyou use --rename switch with multiple items, CP \
    \n\t\texits.\n
    \n  --relaxed\tIgnores bad paths unless they're all bad but warns\
    \n\t\tyou about them. Ignores in-appropriate rename switch\
    \n\t\twithout exiting. This is default behavior. You can \
    \n\t\tmake strict the default behavior by editing the \
    \n\t\tCP script and setting: \n
    \n\t\teasy_going=false.\n
    \n  --help-all\tShows help specific to cp (in addition to CP)."

cp_hlp="\n\nRegular cp command's switches will still work when using CP.\
    \nHere is the help out of the original cp command... \
    \n\n===============================================================================\
    \n          cp specific help: \
    \n===============================================================================\n"

outro1="\n******************************************************************************\
    \n******************************************************************************\
    \n******************************************************************************\
    \n        USE THIS SCRIPT WITH CARE, TYPOS WILL GIVE YOU PROBLEMS...\
    \n******************************************************************************\
    \n******************************* HIT q TO EXIT ********************************\
    \n******************************************************************************"


#count and classify arguments that were inputed into script, output help message if needed
while true; do
    eval input="\$$n"
    in_=${input::1}

    if [ -z "$input" -a $n = 1 ]; then input="--help"; fi 

    if [ "$input" = "-h" -o "$input" = "--help" -o "$input" = "-?" -o "$input" = "--help-all" ]; then
        if [ "$input" = "--help-all" ]; then 
            echo -e "$help"$cp_hlp > /tmp/cp.hlp 
            cp --help >> /tmp/cp.hlp
            echo -e "$outro1" >> /tmp/cp.hlp
            cat /tmp/cp.hlp|less
            cat /tmp/cp.hlp
            rm /tmp/cp.hlp
        else
            echo -e "$help" "$outro1"|less
            echo -e "$help" "$outro1"
        fi
        exit
    fi

    if [ -z "$input" ]; then
        count_i=$(expr $count_i - 1 ) # remember, last item is destination and it's not included in cound
        break 
    elif [ "$in_" = "-" ]; then
        count_s=$(expr $count_s + 1 )
    else
        count_i=$(expr $count_i + 1 )
    fi
    n=$(expr $n + 1)
done

#error condition: no items to copy or no destination
    if [ $count_i -lt 0 ]; then 
            echo "Error: You haven't listed any items for copying. Exiting." # you didn't put any items for copying
    elif [ $count_i -lt 1 ]; then
            echo "Error: Copying usually involves a destination. Exiting." # you put one item and no destination
    fi

#reset the counter and grab content of arguments, aka: switches and item paths
n=1
while true; do
        eval input="\$$n" #input=$1,$2,$3,etc...
        in_=${input::1} #first letter of $input

        if [ "$in_" = "-" ]; then
            if [ "$input" = "--rename" ]; then 
                rename=true #my custom switches
            elif [ "$input" = "--strict" ]; then 
                easy_going=false #exit script if even one of the non-destinations item is not found
            elif [ "$input" = "--relaxed" ]; then 
                easy_going=true #continue script if at least one of the non-destination items is found
            elif [ "$input" = "--quiet" ]; then 
                verbal=""
            else
                #m=$(expr $m + 1);eval switch$m="$input" #input is a switch, if it's not one of the above, assume it belongs to cp.
                switch_list="$switch_list \"$input\""
            fi                                  
        elif ! [ -z "$input" ]; then #if it's not a switch and input is not empty, it's a path
                i=$(expr $i + 1)
                if [ ! -f "$input" -a ! -d "$input" -a "$i" -le "$count_i" ]; then 
                    err=$(expr $err + 1 ); error_list="$error_list\npath does not exit: \"b\""
                else
                    if [ "$i" -le "$count_i" ]; then 
                        eval item$i="$input" 
                        item_list="$item_list \"$input\""
                    else
                        destination="$input" #destination is last items entered
                    fi
                fi
        else
            i=0
            m=0
            n=1                     
            break
        fi      
        n=$(expr $n + 1)
done

#error condition: some or all item(s) being copied don't exist. easy_going: continue if at least one item exists, warn about rest, not easy_going: exit.
#echo "err=$err count_i=$count_i"
if [ "$easy_going" != true -a $err -gt 0 -a $err != $count_i ]; then 
    echo "Some of the paths you entered are incorrect. Script is running in strict mode and will therefore exit."
    echo -e "Bad Paths: $err $error_list"
    exit
fi

if [ $err = $count_i ]; then
    echo "ALL THE PATHS you have entered are incorrect! Exiting."
    echo -e "Bad Paths: $err $error_list"
fi

#one item to one destination:
#------------------------------
#assumes that destination is folder, it does't exist, it will create it. (so copying /a/b/c/d/firefox to /e/f/firefox will result in /e/f/firefox/firefox
#if -rename switch is given, will assume that the top element of destination path is the new name for the the item being given.

#multi-item to single destination:
#------------------------------
#assumes destination is a folder, gives error if it exists and it's a file. -rename switch will be ignored.

#ERROR CONDITIONS: 
# - multiple items being sent to a destination and it's a file.
# - if -rename switch was given and multiple items are being copied, rename switch will be ignored (easy_going). if not easy_going, exit.
# - rename option but source is folder, destination is file, exit.
# - rename option but source is file and destination is folder. easy_going: option ignored.

if [ -f "$destination" ]; then
    if [ $count_i -gt 1 ]; then 
        echo "Error: You've selected a single file as a destination and are copying multiple items to it. Exiting."; exit
    elif [ -d "$item1" ]; then
        echo "Error: Your destination is a file but your source is a folder. Exiting."; exit
    fi
fi
if [ "$rename" = true ]; then
    if [ $count_i -gt 1 ]; then
        if [ $easy_going = true ]; then
            echo "Warning: you choose the rename option but are copying multiple items. Ignoring Rename option. Continuing."
        else
            echo "Error: you choose the rename option but are copying multiple items. Script running in strict mode. Exiting."; exit
        fi
    elif [ -d "$destination" -a -f "$item1" ]; then
        echo -n "Warning: you choose the rename option but source is a file and destination is a folder with the same name. "
        if [ $easy_going = true ]; then
            echo "Ignoring Rename option. Continuing."
        else
            echo "Script running in strict mode. Exiting."; exit
        fi
    else
        dest_jr=$(dirname "$destination")
        if [ -d "$destination" ]; then item_list="$item1/*";fi
        mkdir -p "$dest_jr"
    fi
else
    mkdir -p "$destination"
fi

eval cp $switch_list $verbal $item_list "$destination"

cp_err="$?"
if [ "$cp_err" != 0 ]; then 
    echo -e "Something went wrong with the copy operation. \nExit Status: $cp_err"
else 
    echo "Copy operation exited with no errors."
fi

exit

এটি সম্ভবত একটি ওভারকিল, তবে বেশ দক্ষ, প্রত্যাশার মতো কাজ করে, আপনাকে ধন্যবাদ স্যার।
এক্সেড্রেট

2

cp একাধিক ব্যবহার রয়েছে:

$ cp --help
Usage: cp [OPTION]... [-T] SOURCE DEST
  or:  cp [OPTION]... SOURCE... DIRECTORY
  or:  cp [OPTION]... -t DIRECTORY SOURCE...
Copy SOURCE to DEST, or multiple SOURCE(s) to DIRECTORY.

@ অ্যান্ড্রোসের উত্তরটি এর জন্য কাজ করে

cp SOURCE DEST

শৈলী cp, কিন্তু আপনি যদি এটি ব্যবহার করেন তবে ভুল কাজ করে

cp SOURCE... DIRECTORY/

শৈলী cp

আমি মনে করি যে "ডিইএসটি" এই ব্যবহারের পিছনে পিছনে ছাড়াই অস্পষ্ট (যেমন যেখানে লক্ষ্য ডিরেক্টরিটি এখনও উপস্থিত নেই), সম্ভবত এটিই এর cpজন্য কোনও বিকল্প যুক্ত করেনি added

সুতরাং এখানে এই ফাংশনের আমার সংস্করণটি যা গন্তব্যস্থলীর উপর একটি পিছনে স্ল্যাশ প্রয়োগ করে:

cp-p() {
  last=${@: -1}

  if [[ $# -ge 2 && "$last" == */ ]] ; then
    # cp SOURCE... DEST/
    mkdir -p "$last" && cp "$@"
  else
    echo "cp-p: (copy, creating parent dirs)"
    echo "cp-p: Usage: cp-p SOURCE... DEST/"
  fi
}

2

ঠিক একই সমস্যা ছিল। আমার পন্থাটি ছিল কেবল ফাইলগুলি সংরক্ষণাগারে রাখার মতো:

tar cf your_archive.tar file1 /path/to/file2 path/to/even/deeper/file3

আর্কাইভের মধ্যে ট্যারটি স্বয়ংক্রিয়ভাবে ফাইলগুলিকে উপযুক্ত কাঠামোর মধ্যে সঞ্চয় করে। আপনি যদি চালান

tar xf your_archive.tar

ফাইলগুলি কাঙ্ক্ষিত ডিরেক্টরি কাঠামোতে বের করা হয়।


1

হেল্প_স্যাপ এবং স্পঞ্জম্যান দ্বারা উপরে প্রস্তাবিত হিসাবে আপনি বিদ্যমান ডিরেক্টরিতে ফাইলগুলি অনুলিপি করতে বা নতুন গন্তব্য ডিরেক্টরি তৈরি করতে পারেন যদি সেগুলি ইতিমধ্যে না থাকে তবে আপনি 'ইনস্টল' কমান্ডটি ব্যবহার করতে পারেন।

বিকল্প 1 install -D filename some/deep/directory/filename
একটি নতুন বা বিদ্যমান ডিরেক্টরিতে ফাইল অনুলিপি করে এবং ফাইলের নাম ডিফল্ট 755 অনুমতি দেয়

বিকল্প 1 install -D filename -m640 some/deep/directory/filename
হিসাবে বিকল্প 2 কিন্তু ফাইলের নাম দেয় 640 অনুমতি।

অপশন 2 install -D filename -m640 -t some/deep/directory/
অনুযায়ী বিকল্প 3 তবে ফাইলের নামকে লক্ষ্য ডিরেক্টরিতে লক্ষ্য করে যাতে ফাইলের নাম এবং লক্ষ্য উভয় ক্ষেত্রেই লেখার প্রয়োজন হয় না to

অপশন 3 install -D filena* -m640 -t some/deep/directory/
অনুযায়ী বিকল্প 4 তবে একাধিক ফাইলের জন্য ওয়াইল্ডকার্ড ব্যবহার করে।

এটি উবুন্টুতে দুর্দান্তভাবে কাজ করে এবং একক ধাপে দুটি পদক্ষেপ (ডিরেক্টরি নির্মাণের পরে ফাইল অনুলিপি) একত্রিত করে।


1

এটি খুব দেরি হয়ে গেছে তবে এটি কোনও উপদ্রবকে কোথাও সাহায্য করতে পারে। আপনার যদি 'অটো' ফোল্ডারগুলি তৈরি করতে চান তবে আরএসএনসি আপনার সেরা বন্ধু হওয়া উচিত। আরএসআইএনসি / পাথ / টু / সোর্সফাইলে / পাথ / টু / ট্রেজেটডির / থ্যাডোসটেক্সিস্ট /


0
rsync file /path/to/copy/file/to/is/very/deep/there

আপনার যদি সঠিক ধরণের থাকে তবে এটি কাজ করতে পারে rsync


এটি আমার পক্ষে কাজ করে না - আমি গন্তব্যস্থলে "এ জাতীয় কোনও ফাইল বা ডিরেক্টরি নেই"
রিচ

0

অস্তিত্বহীন পথে উত্স থেকে অনুলিপি করুন

mkdir p /destination && cp r /source/ $_

দ্রষ্টব্য: এই কমান্ডটি সমস্ত ফাইল অনুলিপি করে

cp –r সমস্ত ফোল্ডার এবং এর সামগ্রী অনুলিপি করার জন্য

$_ শেষ কমান্ডে তৈরি করা গন্তব্য হিসাবে কাজ করুন



-1

বলি আপনি এমন কিছু করছেন

সিপি file1.txt এ / বি / সি / ডি / file.txt

যেখানে এ / বি / সি / ডি হ'ল ডিরেক্টরিগুলি এখনও বিদ্যমান নেই

একটি সম্ভাব্য সমাধান নিম্নরূপ:

DIR=$(dirname A/B/C/D/file.txt)
# DIR= "A/B/C/D"
mkdir -p $DIR
cp file1.txt A/B/C/D/file.txt

আশা করি এইটি কাজ করবে!

আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.