শেষ / পরে সমস্ত অক্ষর কাটা


14

সর্বশেষ '/' এর পরে আমি সমস্ত অক্ষর কীভাবে কাটব?

এই বার্তা

xxxx/x/xx/xx/xxxx/x/yyyyy
xxx/xxxx/xxxxx/yyy

ফিরে আসা উচিত

xxxx/x/xx/xx/xxxx/x
xxx/xxxx/xxxxx

ভাল প্রশ্ন, আমি ঠিক বুঝতে পেরেছি যে আমরা প্রশ্নটি একইভাবে বুঝতে পারি না
ফলসিয়েন

3
কমান্ড basenameএবং dirnameএটি ইতিমধ্যে করুন।
মাইকেল হ্যাম্পটন

আমি মনে করি না যে প্রশ্নের # 5 টি সম্পাদনাটি সঠিক ছিল। "কাট" শব্দটি ব্যবহার করা অস্পষ্ট হতে পারে; আপনি যদি কিছু কাটেন, আপনি কি সেই অংশটি ফেলে দেন, বা আপনি কেবল তা রাখছেন? যাইহোক, পূর্ববর্তী শব্দ "এবং" / "এর আগে যা আছে তা বাদ দেওয়া অস্পষ্ট ছিল। এটি এর বিপরীতে পরিবর্তন করা হয়েছিল।
উদাহরণস্বরূপ 0

@ ইগমন্ট "কাট" শব্দটি মূল থেকেই প্রকাশিত হয়েছিল: "শেষের পরে আমাকে কেবল চরচরগুলিই /কাটতে হবে" "হয়ে গেল" শেষ '/' পরে আমি সমস্ত চরিত্রকে কীভাবে কাটব ? " যা বাক্যবিন্যাসের একটি পরিবর্তন যা যুক্তিসঙ্গত অর্থটি রাখে, আইএমও। তোমার কিছু হয়ে গেলে আমি "ফেরত কি ..." দ্ব্যর্থক অংশ অনুভূত: উদাহরণ কি আগে রাখা বলে মনে হচ্ছে /। উদাহরণটি, যাইহোক, এটি পরিষ্কার করে তোলে।
মুড়ু

@ মুরু আমি সম্পাদনার কথা বলছি যা উদাহরণগুলি যুক্ত করেছে, আপনার সম্পাদনা নয়।
উদাহরণস্বরূপ

উত্তর:


15

আপনি যদি "কাটা অংশ" পেতে চান

yyy
yyyyy

তুমি ব্যবহার করতে পার

sed 's|.*/||' 

যেমন।

echo "xxx/xxxx/xxxxx/yyy" | sed 's|.*/||'
echo "xxxx/x/xx/xx/xxxx/x/yyyyy" | sed 's|.*\/||'

আউটপুট

yyy
yyyyy

(দ্রষ্টব্য: এটি / এর ক্ষেত্রে পৃথক পৃথক পৃথক পৃথক পৃথক ব্যবহার করার জন্য সেডের ক্ষমতা ব্যবহার করে |, s কমান্ডে)


আপনি যদি স্ট্রিংয়ের সূচনা পেতে চান:

xxx/xxxx/xxxxx
xxxx/x/xx/xx/xxxx/x

তুমি ব্যবহার করতে পার

sed 's|\(.*\)/.*|\1|'

যেমন।

echo "xxx/xxxx/xxxxx/yyy" | sed 's|\(.*\)/.*|\1|'
echo "xxxx/x/xx/xx/xxxx/x/yyyyy" | sed 's|\(.*\)/.*|\1|'

আউটপুট

xxx/xxxx/xxxxx
xxxx/x/xx/xx/xxxx/x

6
হাই, এই ক্ষেত্রে আপনি ডিলিমিটারটি পরিবর্তন করতে পারেন, উদাহরণস্বরূপ #পরিবর্তে /। এছাড়াও আপনি বিকল্প ব্যবহার করতে পারেন -rযদি আপনি `পালানোর \` প্রতিটি বিশেষ অক্ষর চাই না: sed -r 's#(^.*)/.*$#\1#'
pa4080

1
আমি ব্যবহার করার জন্য একটি প্রস্তাবিত সম্পাদনা জমা দিয়েছি পরিবর্তে /. যদি আপনি এটি পছন্দ না করেন তবে আমি আপনাকে এটি "প্রত্যাখ্যান ও সম্পাদনা" করার পরামর্শ দিচ্ছি এবং "ভিক্ষা "টিকে" শুরু "হিসাবে পরিবর্তন করতে চাই। (প্রত্যাখ্যান + সম্পাদনা করুন, কারণ এইভাবে এটি রোবো-অনুমোদনকারীদের দ্বারা অনুমোদিত হবে না ternative বিকল্পভাবে, যদি অনুমোদিত হয়ে যায় এবং আপনি এটি পছন্দ করেন না তবে কেবল পরিবর্তনটি রোল করুন))
মার্টিন বোনার মনিকা

18

আপনি কাটিং থাকেন বন্ধ স্ট্রিং প্রান্ত, dirnameবিল মাপসই পারে:

$ dirname xxxx/x/xx/xx/xxxx/x/yyyyy
xxxx/x/xx/xx/xxxx/x
$ _

আপনি যদি স্ট্রিংয়ের শেষ অংশটি আলাদা করার চেষ্টা করছেন তবে ব্যবহার করুন echo /$(basename "$str")

$ str=xxxx/x/xx/xx/xxxx/x/yyyyy
$ echo /$(basename "$str")
/yyyyy
$ _

3
সত্যিই, কেন ওএসের সাহায্যে ইনস্টল করা ইউটিলিটিগুলি ব্যবহারের পরিবর্তে কেউ কেন সেড (বা অ্যাড, বা অন্য কোনও অনুরূপ পদ্ধতি) জড়িত একটি উত্তর প্রস্তাব বা গ্রহণ করবে me
অস্পেক্স

@ অ্যাসপেক্স আমি অনুমান করেছিলাম এটি কেবল কারণ dirnameএবং basenameব্যাপকভাবে জানা যায় না, sedএবং awkহয়।
ভোলকার সিগেল

@ অ্যাসপেক্স: যেহেতু ডারনাম এবং বেসনেম স্টিডিনে কাজ করে না, কাজেই cat text | basenameকাজ করবে না। সুতরাং ওপি-র প্রশ্নের যথাযথ সমাধান ব্যবহার করে dirnameএবং এর মধ্যে basenameজড়িত xargsইত্যাদি
পোড

16

প্যারামিটার প্রসারণ bash

আপনি প্যারামিটার সম্প্রসারণ ব্যবহার করতে পারেন bashএই ক্ষেত্রে

  • ${parameter%word}যেখানে wordহয়/*
  • ${parameter##word}যেখানে wordহয়*/

উদাহরণ:

শেষ অংশটি সরান

$ asdf="xxx/xxxx/xxxxx/yyy"
$ echo ${asdf%/*}
xxx/xxxx/xxxxx

এটিতে বর্ণিত হয়েছে man bash:

${parameter%word}
${parameter%%word}
      Remove matching suffix pattern.  The word is expanded to produce
      a pattern just as in pathname expansion.  If the pattern matches
      a  trailing portion of the expanded value of parameter, then the
      result of the expansion is the expanded value of parameter  with
      the  shortest  matching  pattern (the ``%'' case) or the longest
      matching pattern (the ``%%'' case) deleted.  If parameter  is  @
      or  *,  the  pattern  removal operation is applied to each posi‐
      tional parameter in turn, and the  expansion  is  the  resultant
      list.   If  parameter is an array variable subscripted with @ or
      *, the pattern removal operation is applied to  each  member  of
      the array in turn, and the expansion is the resultant list.

শেষ অংশ বাদে সমস্ত অপসারণ করুন

$ asdf="xxx/xxxx/xxxxx/yyy"
$ echo ${asdf##*/}
yyy

আপনি যেমন একটি স্ল্যাশ যোগ করতে পারেন

$ echo /${asdf##*/}
/yyy

সম্পাদিত প্রশ্ন অনুসারে একটি নির্দিষ্ট উদাহরণে আপনি যা চেয়েছিলেন ঠিক তা পেতে। তবে প্রশ্নটি বেশ কয়েকটি লোক এর পরে সম্পাদনা করেছে এবং আপনি এখন কী চান তা জানা সহজ নয়।

এটিতে বর্ণিত হয়েছে man bash:

${parameter#word}
${parameter##word}
      Remove matching prefix pattern.  The word is expanded to produce
      a pattern just as in pathname expansion.  If the pattern matches
      the  beginning of the value of parameter, then the result of the
      expansion is the expanded value of parameter with  the  shortest
      matching  pattern  (the ``#'' case) or the longest matching pat‐
      tern (the ``##'' case) deleted.  If parameter is  @  or  *,  the
      pattern  removal operation is applied to each positional parame‐
      ter in turn, and the expansion is the resultant list.  If param‐
      eter  is  an array variable subscripted with @ or *, the pattern
      removal operation is applied to each  member  of  the  array  in
      turn, and the expansion is the resultant list.

10

আর একটি উপায় হ'ল grepপ্রতি লাইন এবং এর অনুসরণ অনুসারে কেবল শেষ স্ল্যাশ প্রদর্শন করতে ব্যবহার করা:

$ grep -o '/[^/]*$' example.txt
/yyy
/yyyyy

ব্যাখ্যা:

-ogrepপুরো লাইনের পরিবর্তে কেবল লাইনের মিলের অংশটি দেখাতে বলে ।

প্যাটার্নটি /[^/]*$আক্ষরিক স্ল্যাশের সাথে মিলে যায় যার /পরে লাইন শেষ হওয়া অবধি [^/]সংখ্যক বার স্ল্যাশ বাদে কোনও অক্ষর অনুসরণ করা হয় ।*$


8

অন্যরা আরও "বুদ্ধিমান" উত্তর পোস্ট করেছেন বলেই এখানে কিছুটা নির্বোধ উত্তর দেওয়া হয়েছে:

rev | cut -d/ -f1 | rev

revপ্রতিটি লাইনের অক্ষরকে বিপরীত করে, যেমন abcd/ef/gহয় g/fe/dcba। তারপরে cutপ্রথম বিভাগটি কেটে দেয়। শেষ পর্যন্ত এটি আবার বিপরীত।


2
এই জবাবটি অকার্যকর হওয়া সত্ত্বেও, বিশেষ করে শেল নদীর গভীরতানির্ভর কারণে, আমি এই উত্তরটি পছন্দ করি :)
দুলিয়ে

রাজি হয়েছে - বুদ্ধিমান নয়, বদস!
ভোলকার সিগেল

3

এর সাথে ক্লাসিক সমাধান awk, যা /ইনপুট এবং আউটপুট উভয়ের ক্ষেত্রে ফিল্ড বিভাজক হিসাবে বিবেচনা করে এবং শেষ ক্ষেত্রটি খালি স্ট্রিংয়ে সেট করে (যা ক্ষেত্রের NFপরিবর্তনের ক্ষেত্রের সংখ্যার সত্যই "অবচয়" ):

$ echo "xxx/xxxx/xxxxx/yyy"|awk  'BEGIN{OFS=FS="/"};{$NF="";print $0}'
xxx/xxxx/xxxxx/

খাটো, ফেডোরকি হিসাবে মন্তব্যগুলিতে উল্লেখ করেছেন:

$ echo "xxx/xxxx/xxxxx/yyy"|awk  'BEGIN{OFS=FS="/"};NF--'
xxx/xxxx/xxxxx/

তার মধ্যে পার্থক্য হ'ল awk'এক্সিকিউশন পরিবেশে পথ রক্ষা করা হবে যা নদীর গভীরতানির্ণয়কে বাঁচিয়ে রাখবে তবে awkঅংশটিকে আরও ভার্জবস করে তোলে :

mypath="xxx/xxxx/xxxxx/yyy" awk  'BEGIN{OFS=FS="/"; sub(/\/([^\/]*)$/,"",ENVIRON["mypath"]);print(ENVIRON["mypath"]) };'

1
খুব ভার্জোজ, শুধু কেন নয় NF--? এইভাবে আপনি ব্লেড ব্লেডকে টানছেন print
ফেডোরকিউ

3

অ্যাডমন্টের উত্তরে যুক্ত করা হচ্ছে কারণ প্রশ্নটি সম্পাদনা করা হয়েছে ...

যদি আপনি -f1 দিয়ে প্রথম ক্ষেত্রটি সরাতে চান - কমপ্লিট ব্যবহার করুন ।

echo "xxxx/x/xx/xx/xxxx/x/yyyyy"|rev|cut -d/ -f1 --complement|rev
xxxx/x/xx/xx/xxxx/x

echo "xxxx/x/xx/xx/xxxx/x/yyyyy"|rev|cut -d/ -f1|rev
yyyyy

এছাড়াও, কোনও স্ল্যাশ না থাকা ইনপুটগুলির সাথে কী ঘটতে হবে সে সম্পর্কে প্রশ্নটি পুরোপুরি পরিষ্কার নয়। xxxx => xxxx বা xxxx => কিছুই নয়


: আপনি চাইলে এটিকে একটি সম্পাদনা পরামর্শ দিতে পারেন askubuntu.com/posts/1010356/edit
muru

@ মুরু ওপি 1 জন ব্যবহারকারী। 2k এ সম্পাদনা সুবিধা দেওয়া হয় না? askubuntu.com/help/privileges/edit
Sergiy Kolodyazhnyy

@ সার্জিইক্লোডিয়াজহনি যে কেউ সম্পাদনার পরামর্শ দিতে পারে।
মারু

+1 - আমি --complementআগে বিকল্পটি লক্ষ্য করিনি এবং ম্যান পৃষ্ঠাটি বিজ্ঞপ্তিযুক্ত। পরিপূরক মানে পরিপূরক। আমি একটা চমৎকার কাটা টিউটোরিয়াল যা এ কভার পাওয়া yourownlinux.com/2015/05/... এটা কেমন -vমধ্যে grep। যা মেলে তা বাদ দিয়ে আমাকে সবকিছু দাও।
জো

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