अजगर एक लंबी स्ट्रिंग काटता है


246

पायथन में 75 वर्णों में एक तार को कैसे काटता है?

यह जावास्क्रिप्ट में कैसे किया जाता है:

var data="saddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddsaddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddsadddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddd"
var info = (data.length > 75) ? data.substring[0,75] + '..' : data;

जवाबों:


427
info = (data[:75] + '..') if len(data) > 75 else data

58
मैं शायद len(data) > 77डबल डॉट्स के लिए खाते में स्थिति को बदल दूंगा (यह केवल एक डॉट के साथ इसे बदलने के लिए केवल अंतिम चरित्र को काट देना बेकार है)।
hasen

5
@ सहजें: यह मूल कोड के अनुरूप नहीं होगा, लेकिन यह एक अच्छा सुझाव है जिसे मुझे पहली बार में इंगित करना चाहिए था।
मार्सेलो कैंटोस

2
ध्यान दें कि शामिल किए गए parens निश्चित रूप से वैकल्पिक हैं।
टेलर एड्मिस्टन

10
@TaylorEdmiston सच है, लेकिन वे उन लोगों के लिए काफी मददगार हैं, जो दैनिक उपयोग की जाने वाली 5 से 10 भाषाओं में सभी पूर्ववर्ती नियमों को याद नहीं करते हैं।
मार्सेलो कैंटोस

2
@ एंथनी ए स्लाइस
मार्सेलो कैंटोस

126

और भी छोटा:

info = data[:75] + (data[75:] and '..')

2
यह करने के लिए मजेदार दृष्टिकोण। हालांकि यह अभी भी एक समग्र एक लाइनर है। ^ ^
Cheery

3
यदि आप '..' को शामिल करते हैं, तो इस समाधान में 77 वर्ण नहीं हैं?
मार्क चेकरियन

क्या यह दो स्लाइस ऑपरेशन नहीं कर रहा है? मुझे आश्चर्य है कि कैसे इस प्रदर्शन का कहना है की तुलना में stackoverflow.com/a/52279347/1834057 , जब प्रदर्शन महत्वपूर्ण है
निकोलस हैमिल्टन

1
निश्चित रूप से, अच्छा मूल उत्तर, लेकिन मार्सेलो का उत्तर बेहतर है क्योंकि यह अधिक स्पष्ट है और इस प्रकार पठनीय है (और इस प्रकार पाइथोनिक)।
सितारनफ़

114

और भी संक्षिप्त:

data = data[:75]

अगर यह 75 अक्षरों से कम है तो कोई बदलाव नहीं होगा।


9
संभवत: वह एक दीर्घवृत्त चाहता है यदि स्ट्रिंग को काट दिया जाए।
फोगबर्ड

4
तुम सही हो - मैंने कभी इस पर ध्यान नहीं दिया। मैं अन्य उत्तरों की तुलना में ऐसा करने का बेहतर तरीका नहीं सोच सकता।
नील

82

यदि आप पायथॉन 3.4+ का उपयोग कर रहे हैं, तो आप textwrap.shortenमानक पुस्तकालय से उपयोग कर सकते हैं :

दी गई चौड़ाई में फिट होने के लिए दिए गए पाठ को संक्षिप्त और छोटा करें।

पाठ में पहले व्हाट्सएप का पतन हो गया है (सभी व्हाट्सएप को सिंगल स्पेस द्वारा बदल दिया गया है)। यदि परिणाम चौड़ाई में फिट बैठता है, तो इसे वापस कर दिया जाता है। अन्यथा, पर्याप्त शब्द अंत से हटा दिए जाते हैं ताकि शेष शब्द प्लस प्लेसहोल्डर चौड़ाई में फिट हो जाएं:

>>> textwrap.shorten("Hello  world!", width=12)
'Hello world!'
>>> textwrap.shorten("Hello  world!", width=11)
'Hello [...]'
>>> textwrap.shorten("Hello world", width=10, placeholder="...")
'Hello...'

8
यह वास्तव में लंबे तार (कोई रिक्त स्थान) पर अपनी पैंट को बकवास करने के लिए लगता है और केवल इलिप्सिस आउटपुट करता है।
इलाब्राफोर्ड

5
@elBradford (और रुचि अन्य): कि है, क्योंकि shorten()ट्रंकेटस शब्द , नहीं एकल वर्ण। मैंने खोज की, लेकिन एकल वर्णों को क्लिप करने के लिए कॉन्फ़िगर करने shorten()या TextWrapperइंस्टेंस करने का कोई तरीका नहीं है और न ही शब्द।
14

और यह की पंक्ति विराम को हटाने कष्टप्रद पक्ष प्रभाव पड़ता है
havlock

इससे ओपी का सवाल हल नहीं होता। यह शब्द से छंटनी करता है और यहां तक ​​कि व्हाट्सएप को हटा देता है।
फ्लोरियन वेंडेलबोर्न

32

एक Django समाधान के लिए (जिसका उल्लेख प्रश्न में नहीं किया गया है):

from django.utils.text import Truncator
value = Truncator(value).chars(75)

समस्या की सराहना करने के लिए Truncator के स्रोत कोड पर एक नज़र डालें: https://github.com/django/django/blob/master/django/utils/text.py#L66

Django के साथ ट्रंकेशन के संबंध में: Django HTML ट्रंकेशन


यह अनावश्यक रूप से जोड़ों को निम्न स्तर के तर्क को दजंगो के लिए। इसकी सिफारिश नहीं करेंगे।
केवैन

9

आप इस एक-लाइनर का उपयोग कर सकते हैं:

data = (data[:75] + '..') if len(data) > 75 else data

2
क्या [:n]कहा जाता है ताकि मैं इसे प्रलेखन में देख सकता हूं?
Oldboy

2
टुकड़ा करने की क्रिया: stackoverflow.com/questions/509211/…
Bl00dh0und

9

रेगेक्स के साथ:

re.sub(r'^(.{75}).*$', '\g<1>...', data)

लंबे तार काटे जाते हैं:

>>> data="11111111112222222222333333333344444444445555555555666666666677777777778888888888"
>>> re.sub(r'^(.{75}).*$', '\g<1>...', data)
'111111111122222222223333333333444444444455555555556666666666777777777788888...'

छोटे तार कभी काटे नहीं जाते:

>>> data="11111111112222222222333333"
>>> re.sub(r'^(.{75}).*$', '\g<1>...', data)
'11111111112222222222333333'

इस तरह, आप स्ट्रिंग के मध्य भाग को "कट" भी कर सकते हैं, जो कुछ मामलों में अच्छा है:

re.sub(r'^(.{5}).*(.{5})$', '\g<1>...\g<2>', data)

>>> data="11111111112222222222333333333344444444445555555555666666666677777777778888888888"
>>> re.sub(r'^(.{5}).*(.{5})$', '\g<1>...\g<2>', data)
'11111...88888'

जब आप अपने तार में रिक्त स्थान है अच्छी तरह से काम नहीं किया
होम्स

आप इस तरह के एक साधारण मामले के लिए रेगेक्स का उपयोग क्यों करेंगे?
बोरा एम। अल्पर

5

इस विधि का उपयोग नहीं करता है अगर:

data[:75] + bool(data[75:]) * '..'


4
मैंने इसे केवल यह दिखाने के लिए लिखा था कि यह संभव है। यह अजगर की पठनीयता के दर्शन के खिलाफ है। यह अन्य "अगर" आधारित विधियों के साथ तुलना में कोई प्रदर्शन लाभ नहीं है। मैं कभी भी इसका उपयोग नहीं करता हूं और मेरा सुझाव है कि आप इसका भी उपयोग करें।
सासन

4
limit = 75
info = data[:limit] + '..' * (len(data) > limit)

1
यह सबसे सुरुचिपूर्ण समाधान है। इसके अतिरिक्त, मैं 75विसंगतियों से बचने के लिए चर चर (इस मामले में ) को एक चर में निकालूंगा। limit = 75; info = data[:limit] + '..' * (len(data) > limit)
इकाफमैन

3

फिर भी एक और उपाय। के साथ Trueऔर Falseअंत में आपको परीक्षण के बारे में थोड़ी प्रतिक्रिया मिलती है।

data = {True: data[:75] + '..', False: data}[len(data) > 75]

2

बस में:

n = 8
s = '123'
print  s[:n-3] + (s[n-3:], '...')[len(s) > n]
s = '12345678'
print  s[:n-3] + (s[n-3:], '...')[len(s) > n]
s = '123456789'     
print  s[:n-3] + (s[n-3:], '...')[len(s) > n]
s = '123456789012345'
print  s[:n-3] + (s[n-3:], '...')[len(s) > n]

123
12345678
12345...
12345...

पिछले सभी उत्तर ओपी वास्तव में चाहते थे पर विचार करने के लिए उपेक्षा करते हैं - एक आउटपुट स्ट्रिंग अब 75 वर्णों से अधिक नहीं है। "मैं जो कहता हूं, उसे वैसा मत करो, जैसा मैं चाहता हूं वैसा ही करो" प्रोग्रामिंग सिद्धांत। पूर्णता के लिए आप n <3 के कोने के मामले को जोड़कर ठीक कर सकते हैं: यदि n> 2 और s [: n]
डेव

1
       >>> info = lambda data: len(data)>10 and data[:10]+'...' or data
       >>> info('sdfsdfsdfsdfsdfsdfsdfsdfsdfsdfsdf')
           'sdfsdfsdfs...'
       >>> info('sdfsdf')
           'sdfsdf'
       >>> 

1
कृपया अपना उत्तर बताएं?
ग्वेंके ३ '

इस फ़ंक्शन के समान उदाहरण info2 (डेटा) को परिभाषित करते हैं: यदि लेन (डेटा)> 10: रिटर्न डेटा [: 10] + '...' और:: डेटा की वापसी लंबोर्ड निर्देश एक कार्यात्मक शैली में पूर्व डिजाइन = लैम्ब्डा एक्स: x + 1
डिफ

1

आप वास्तव में एक अजगर स्ट्रिंग को "काट" नहीं सकते हैं जैसे आप एक गतिशील रूप से आवंटित सी स्ट्रिंग कर सकते हैं। अजगर में स्ट्रिंग्स अपरिवर्तनीय हैं। जैसा कि आप कर सकते हैं एक स्लाइस एक स्ट्रिंग है जैसा कि अन्य उत्तरों में वर्णित है, एक नई स्ट्रिंग की उपज है जिसमें केवल स्लाइस ऑफ़सेट और स्टेप द्वारा परिभाषित वर्ण हैं। कुछ (गैर-व्यावहारिक) मामलों में यह थोड़ा कष्टप्रद हो सकता है, जैसे कि जब आप पायथन को अपनी साक्षात्कार भाषा के रूप में चुनते हैं और साक्षात्कारकर्ता आपको एक स्ट्रिंग में जगह से डुप्लिकेट वर्णों को हटाने के लिए कहता है। रवींद्र।


1
info = data[:min(len(data), 75)

कोड केवल उत्तर आमतौर पर निम्न गुणवत्ता वाले माने जाते हैं। क्या आप अपने उत्तर में स्पष्टीकरण जोड़ सकते हैं।
लेमन काज़ी

0

एक नियमित अभिव्यक्ति की कोई आवश्यकता नहीं है, लेकिन आप स्वीकार किए गए उत्तर में स्ट्रिंग संघनन के बजाय स्ट्रिंग स्वरूपण का उपयोग करना चाहते हैं।

यह संभवतः सबसे अधिक विहित, पाइथोनिक तरीका है dataजो 75 अक्षरों पर स्ट्रिंग को काटता है ।

>>> data = "saddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddsaddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddsadddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddd"
>>> info = "{}..".format(data[:75]) if len(data) > 75 else data
>>> info
'111111111122222222223333333333444444444455555555556666666666777777777788888...'

मुझे यह मज़ेदार लगा कि आपका saddddddd...तार कैसे बदल जाता है 111111...:) मुझे पता है कि यह एक कॉपी-पेस्ट टाइपो है, और मैं नियमित अभिव्यक्तियों के बारे में आपसे सहमत हूँ।
एरिकिलिमानो

0

यहाँ एक फ़ंक्शन है जिसे मैंने एक नए स्ट्रिंग वर्ग के हिस्से के रूप में बनाया है ... यह एक प्रत्यय जोड़ने की अनुमति देता है (यदि ट्रिमिंग के बाद स्ट्रिंग का आकार है और इसे जोड़ना काफी लंबा है - हालांकि आपको पूर्ण आकार को बाध्य करने की आवश्यकता नहीं है)

मैं कुछ चीजों को बदलने की प्रक्रिया में था, इसलिए कुछ बेकार तर्क लागतें हैं (यदि _truncate ... उदाहरण के लिए) जहां यह आवश्यक नहीं है और शीर्ष पर वापसी है ...

लेकिन, डेटा को रौंदने के लिए यह अभी भी एक अच्छा कार्य है ...

##
## Truncate characters of a string after _len'nth char, if necessary... If _len is less than 0, don't truncate anything... Note: If you attach a suffix, and you enable absolute max length then the suffix length is subtracted from max length... Note: If the suffix length is longer than the output then no suffix is used...
##
## Usage: Where _text = 'Testing', _width = 4
##      _data = String.Truncate( _text, _width )                        == Test
##      _data = String.Truncate( _text, _width, '..', True )            == Te..
##
## Equivalent Alternates: Where _text = 'Testing', _width = 4
##      _data = String.SubStr( _text, 0, _width )                       == Test
##      _data = _text[  : _width ]                                      == Test
##      _data = ( _text )[  : _width ]                                  == Test
##
def Truncate( _text, _max_len = -1, _suffix = False, _absolute_max_len = True ):
    ## Length of the string we are considering for truncation
    _len            = len( _text )

    ## Whether or not we have to truncate
    _truncate       = ( False, True )[ _len > _max_len ]

    ## Note: If we don't need to truncate, there's no point in proceeding...
    if ( not _truncate ):
        return _text

    ## The suffix in string form
    _suffix_str     = ( '',  str( _suffix ) )[ _truncate and _suffix != False ]

    ## The suffix length
    _len_suffix     = len( _suffix_str )

    ## Whether or not we add the suffix
    _add_suffix     = ( False, True )[ _truncate and _suffix != False and _max_len > _len_suffix ]

    ## Suffix Offset
    _suffix_offset = _max_len - _len_suffix
    _suffix_offset  = ( _max_len, _suffix_offset )[ _add_suffix and _absolute_max_len != False and _suffix_offset > 0 ]

    ## The truncate point.... If not necessary, then length of string.. If necessary then the max length with or without subtracting the suffix length... Note: It may be easier ( less logic cost ) to simply add the suffix to the calculated point, then truncate - if point is negative then the suffix will be destroyed anyway.
    ## If we don't need to truncate, then the length is the length of the string.. If we do need to truncate, then the length depends on whether we add the suffix and offset the length of the suffix or not...
    _len_truncate   = ( _len, _max_len )[ _truncate ]
    _len_truncate   = ( _len_truncate, _max_len )[ _len_truncate <= _max_len ]

    ## If we add the suffix, add it... Suffix won't be added if the suffix is the same length as the text being output...
    if ( _add_suffix ):
        _text = _text[ 0 : _suffix_offset ] + _suffix_str + _text[ _suffix_offset: ]

    ## Return the text after truncating...
    return _text[ : _len_truncate ]

1
हर एक तर्क और चर में सभी अंडरस्कोर के साथ व्हाट्स?
निकोलस हैमिल्टन

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.