Excel公式 提取文件路徑尾碼

来源:http://www.cnblogs.com/kybs0/archive/2016/11/14/6062889.html
-Advertisement-
Play Games

我們在代碼中獲取一個文件路徑的尾碼,是一個很簡單的事. 如C#中,可以通過new FileInfo(filePath).Extension,或者Path.GetExtension(filePath)獲取。 而Excel的大數據中,直接批量獲取同行單元格內容中文件路徑的尾碼,該如何獲取? 如上,想獲取 ...


我們在代碼中獲取一個文件路徑的尾碼,是一個很簡單的事.

如C#中,可以通過new FileInfo(filePath).Extension,或者Path.GetExtension(filePath)獲取。

而Excel的大數據中,直接批量獲取同行單元格內容中文件路徑的尾碼,該如何獲取?

如上,想獲取文件尾碼,然後從中分析出文件的所屬開發語言。

公式如下:

1、獲取尾碼

=RIGHT(D2,LEN(D2)-FIND("@",SUBSTITUTE(D2,".","@",LEN(D2)-LEN(SUBSTITUTE(D2,".",)))))

過程分析:

我們需要先找到最後的一個字元"."的位置,這樣才能通過Right函數截取相應的長度,獲取尾碼。

而找字元,我們用Find函數就行了。但是怎麼找到那唯一的一個呢?

我們通過先通過LEN(D2)-LEN(SUBSTITUTE(D2,".",)查找字元串中有多少個同樣的字元"." ,然後這個數量也就可以代表最後一個字元的順序。

最後一個字元找到了,我們可以SUBSTITUTE(D2,".","@",LEN(D2)-LEN(SUBSTITUTE(D2,".",)))將它替換成一個在這段內容中不會出現的字元@。

然後直接找字元@就行了,FIND("@",SUBSTITUTE(D2,".","@",LEN(D2)-LEN(SUBSTITUTE(D2,".",)))),找到字元@的位置,再用字元串的總長度減去位置,就能得到字元從右往左的位置。

通過Right函數截取,即可。

2、尾碼得到了,再判斷是何語言。一個所屬開發語言的項目,包含的文件類型都是有規律的。

如C#裡面,類文件是cs。資料庫sql文件,尾碼是sql。

而我們在Excel中只要用if就能判斷出來。

=IF(ISBLANK(D2),"",IF(OR(RIGHT(D2,LEN(D2)-FIND("@",SUBSTITUTE(D2,".","@",LEN(D2)-LEN(SUBSTITUTE(D2,".",)))))="frm",RIGHT(D2,LEN(D2)-FIND("@",SUBSTITUTE(D2,".","@",LEN(D2)-LEN(SUBSTITUTE(D2,".",)))))="bas",RIGHT(D2,LEN(D2)-FIND("@",SUBSTITUTE(D2,".","@",LEN(D2)-LEN(SUBSTITUTE(D2,".",)))))="cls"),"VB",IF(RIGHT(D2,LEN(D2)-FIND("@",SUBSTITUTE(D2,".","@",LEN(D2)-LEN(SUBSTITUTE(D2,".",)))))="cs","C#",IF(OR(RIGHT(D2,LEN(D2)-FIND("@",SUBSTITUTE(D2,".","@",LEN(D2)-LEN(SUBSTITUTE(D2,".",)))))="c",RIGHT(D2,LEN(D2)-FIND("@",SUBSTITUTE(D2,".","@",LEN(D2)-LEN(SUBSTITUTE(D2,".",)))))="h"),"C++",IF(RIGHT(D2,LEN(D2)-FIND("@",SUBSTITUTE(D2,".","@",LEN(D2)-LEN(SUBSTITUTE(D2,".",)))))="sql","SP",IF(RIGHT(D2,LEN(D2)-FIND("@",SUBSTITUTE(D2,".","@",LEN(D2)-LEN(SUBSTITUTE(D2,".",)))))="4gl","4gl",IF(OR(RIGHT(D2,LEN(D2)-FIND("@",SUBSTITUTE(D2,".","@",LEN(D2)-LEN(SUBSTITUTE(D2,".",)))))="bat",RIGHT(D2,LEN(D2)-FIND("@",SUBSTITUTE(D2,".","@",LEN(D2)-LEN(SUBSTITUTE(D2,".",)))))="sh"),"BAT","UnKnown")))))))
View Code

註意一下異常情況,如單元格為空,需要加個判斷IsBlank或者SUBSTITUTE(D2," ","")=""等

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • php面試題之一——PHP核心技術(高級部分) 一、PHP核心技術 1.寫出一個能創建多級目錄的PHP函數(新浪網技術部) <?php /** * 創建多級目錄 * @param $path string 要創建的目錄 * @param $mode int 創建目錄的模式,在windows下可忽略 ...
  • 方法一 方法二 1 echo (strtotime('2007316')-strtotime('2007306'))/(24*3600); // strtotime,將一個英式日期戳轉換成一個unix時間戳,只要格式符合日期格式即可,註意後面6號的時候不能直接寫6.需要寫06,任何情況下不能寫6,否 ...
  • 回調函數、閉包在JS中並不陌生,JS使用它可以完成事件機制,進行許多複雜的操作。PHP中卻不常使用,今天來說一說PHP中中的回調函數和匿名函數。 ...
  • #!/usr/bin/env python# -*- coding:utf-8 -*-"""老規矩以下方法環境2.7.x,請3.x以上版本的朋友記得格式print(輸出內容放入括弧內)字典的基本組成以及用法dict = { key : value }dict[ key ] = value首先來說說字 ...
  • 本文為博主辛苦總結,希望自己以後返回來看的時候理解更深刻,也希望可以起到幫助初學者的作用. 轉載請註明 出自 : "luogg的博客園" 謝謝配合! day08 EL JSTL EL表達式 語法:${} 獲取域中對象的值 域中數組的值 域中集合的值 域中Map集合的值 域中集合有對象或者Bean的值 ...
  • 學習編程語言,列印簡單的金字塔是基礎的案例,在這裡就簡單的寫了個案例,希望能幫助到各位 效果 * *** ***** ******* ********* *********** ************* *************** import java.util.Scanner; //導入輸 ...
  • 1、對象和類的概念: 對象——用電腦語言對問題域中事物的描述,對象通過屬性和方法,來分別表示事物所具有靜態屬性和動態屬性。 類——類是用來描述同一類型的對象的一種抽象的概念,類中定義了這一類對象所具有的靜態和動態屬性。 類可以看做是對象的一種抽象,對象則是類的一個具體實例。 2、類和對象的創建和使 ...
  • 最近在用python寫介面的測試程式,期間用到解析字典獲取某個key的value,由於多個介面返回的字典格式不是固定的並存在多層嵌套的情況。在字典的方法中也沒有找到可直接達到目的的方法(也可能是我對字典的方法瞭解的不深的緣故),於是自己寫了個程式。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...