दो समाधान:
- preg_match()
- pathinfo()
1 के साथ str_replace(): preg_match()
ठीक है, तो समस्या यह है कि आप बैकस्लाश का उपयोग कर रहे हैं। आपको यह सुनिश्चित करना होगा कि अपने फ़ाइलपैथ को परिभाषित करने के लिए डबल कोट्स का उपयोग न करें, क्योंकि बैकस्लैश को एस्केप अनुक्रम के रूप में व्याख्या किया गया है। एकल उद्धरण का प्रयोग करें।
इसके अतिरिक्त, एक regex के साथ, यह बहुत सरल मार्ग के पीछे से आगे बढ़ जब तक आप एक बैकस्लैश हिट द्वारा एक फ़ाइल नाम पाने के लिए है .... चाल .. कि एक बैकस्लैश \\\\
है here's why
अंत में , आप preg_replace का उपयोग नहीं करना चाहते हैं।बस preg_match साथ फ़ाइल नाम ढूंढने:
<?php
// Use single quotes or the backslash will be interpreted as an esacpe sequence
$filepath = '\abc\def\filename.txt';
// You have to use 4 backslashes to represent your single backslash
// The regex picks the characters that are NOT \ from the end of the path
$pattern = '/[^\\\\]+$/';
// Use $matches to store the match
preg_match($pattern, $filepath, $matches);
// Display answer now, or use later
echo $matches[0];
?>
2: str_replace()pathinfo()
के रूप में अन्य लोगों ने कहा के साथ, basename()
एक अच्छा विकल्प है। एक अन्य विकल्प, यदि आपको कोई समस्या है कि आपको बाद में निर्देशिका या अन्य पथ जानकारी की आवश्यकता हो तो लाइन के नीचे pathinfo()
समस्या यह है कि बेसिनम और पथिनोफो दोनों आगे स्लेश मानते हैं, इसलिए आपको अपनी बैकस्लैश को आगे बढ़ाना होगा स्लैश:
उदाहरण:
<?php
// Make sure to use single quotes
$filepath='abc\filename.txt';
// Replace backslash with forward slash
$filepath = str_replace('\\', '/', $filepath);
$path_parts = pathinfo($filepath);
// This is the answer you want
echo $path_parts['basename'], "\n";
// But you also have access to these
echo $path_parts['dirname'], "\n";
echo $path_parts['extension'], "\n";
echo $path_parts['filename'], "\n"; // since PHP 5.2.0
?>
कुछ भी नहीं preg_replace उपयोग करने के साथ पात्रों को बदलने के लिए कोई कारण नहीं है: यहाँ एक बैकस्लैश संस्करण है। इसके बजाय preg_match का उपयोग करने के लिए यह अधिक प्रत्यक्ष है। (कैसे मेरा जवाब देखें)। –