Compare commits
2 Commits
f85890bda8
...
652105f534
Author | SHA1 | Date | |
---|---|---|---|
|
652105f534 | ||
|
bbc4bfd52f |
@ -1,4 +1,5 @@
|
||||
import RuleInterface from "./RuleInterface";
|
||||
import {dealFileName} from "./RuleInterface";
|
||||
import FileObj from "../../vo/FileObj";
|
||||
import path from 'path';
|
||||
|
||||
@ -20,6 +21,9 @@ export default class DeleteRule implements RuleInterface {
|
||||
* 忽略拓展名,true:忽略,false:不忽略
|
||||
*/
|
||||
ignorePostfix: boolean;
|
||||
/*
|
||||
* 是否区分大小写
|
||||
*/
|
||||
regI: boolean;
|
||||
|
||||
constructor(data: any) {
|
||||
@ -32,11 +36,9 @@ export default class DeleteRule implements RuleInterface {
|
||||
|
||||
|
||||
deal(file: FileObj): void {
|
||||
let target = "";
|
||||
if (this.type === 'deleteAll') {
|
||||
file.realName = "";
|
||||
if (!this.ignorePostfix) {
|
||||
file.expandName = "";
|
||||
}
|
||||
target = "";
|
||||
} else {
|
||||
let str = file.realName + (this.ignorePostfix ? "" : file.expandName);
|
||||
let startIndex = this.start.calIndex(str, false);
|
||||
@ -45,19 +47,9 @@ export default class DeleteRule implements RuleInterface {
|
||||
return;
|
||||
}
|
||||
str = str.substring(0, startIndex) + str.substring(endIndex + 1);
|
||||
if (this.ignorePostfix) {
|
||||
file.realName = str;
|
||||
} else {
|
||||
file.expandName = path.extname(str);
|
||||
if (file.expandName.length > 0) {
|
||||
file.realName = str.substring(0, str.lastIndexOf("."));
|
||||
} else {
|
||||
file.realName = str;
|
||||
target = str;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
file.name = file.realName + file.expandName;
|
||||
dealFileName(file, target, this.ignorePostfix);
|
||||
}
|
||||
|
||||
}
|
||||
@ -94,12 +86,13 @@ class DeleteRuleItem {
|
||||
let val = parseInt(this.value);
|
||||
return val > 0 ? val - 1 : str.length + val;
|
||||
} else if (this.type === 'text') {
|
||||
return str.indexOf(this.value);
|
||||
let index = str.indexOf(this.value);
|
||||
return index + (end ? this.value.length - 1 : 0);
|
||||
} else if (this.type === 'end') {
|
||||
return str.length - 1;
|
||||
} else if (this.type === 'reg') {
|
||||
let res = this.reg.exec(str);
|
||||
return res == null ? -1 : (res.index + (end ? 0 : res[0].length));
|
||||
return res == null ? -1 : (res.index + (end ? res[0].length - 1 : 0));
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
|
@ -1,5 +1,7 @@
|
||||
import RuleInterface from "./RuleInterface";
|
||||
import * as ValUtil from "../../../util/ValUtil";
|
||||
import FileObj from "../../vo/FileObj";
|
||||
import {dealFileName} from './RuleInterface';
|
||||
import path from 'path';
|
||||
|
||||
|
||||
@ -10,45 +12,101 @@ export default class ReplaceRule implements RuleInterface {
|
||||
*/
|
||||
type: number;
|
||||
/**
|
||||
* 前面追加
|
||||
* 源
|
||||
*/
|
||||
source: string;
|
||||
/**
|
||||
* 后面追加
|
||||
* 目标
|
||||
*/
|
||||
target: string;
|
||||
/**
|
||||
* 是否正则模式
|
||||
*/
|
||||
regFlag: boolean;
|
||||
/**
|
||||
* 是否区分大小写
|
||||
*/
|
||||
regI: boolean;
|
||||
/**
|
||||
* 是否护理拓展名
|
||||
*/
|
||||
ignorePostfix: boolean;
|
||||
|
||||
constructor(data: any) {
|
||||
this.type = data.type;
|
||||
this.source = data.source;
|
||||
this.target = data.target;
|
||||
this.regFlag = ValUtil.nullToDefault(data.regFlag, false);
|
||||
this.regI = ValUtil.nullToDefault(data.regI, false);
|
||||
this.ignorePostfix = ValUtil.nullToDefault(data.ignorePostfix, false);
|
||||
}
|
||||
|
||||
|
||||
deal(file: FileObj): void {
|
||||
let targetStr = this.ignorePostfix ? file.realName : file.name;
|
||||
let res = this.regFlag ? this.dealReg(targetStr) : this.dealNoReg(targetStr);
|
||||
dealFileName(file, res, this.ignorePostfix);
|
||||
}
|
||||
|
||||
private dealNoReg(targetStr: string): string {
|
||||
let start = 0;
|
||||
let changed = false;
|
||||
for (; ;) {
|
||||
let index = this.type == 1 || this.type == 3 ? file.name.indexOf(this.source, start) : file.name.lastIndexOf(this.source);
|
||||
if (index > -1) {
|
||||
file.name = file.name.substring(0, index) + this.target + file.name.substring(index + this.source.length);
|
||||
start = index + this.target.length;
|
||||
changed = true;
|
||||
if (this.type != 3) {
|
||||
let arr: number[] = [];
|
||||
for (let i = 0; i < (this.type == 1 ? 1 : 1000); i++) {
|
||||
let one = targetStr.indexOf(this.source, start);
|
||||
if (one == -1) {
|
||||
break;
|
||||
}
|
||||
} else {
|
||||
arr.push(one);
|
||||
start = one + this.source.length;
|
||||
}
|
||||
if (arr.length == 0) {
|
||||
return targetStr;
|
||||
}
|
||||
let res = "";
|
||||
let needDealArr: number[] = this.type === 1 ? [arr[0]] : this.type === 2 ? [arr[arr.length - 1]] : arr;
|
||||
let lastIndex = 0;
|
||||
for (let i = 0; i < needDealArr.length; i++) {
|
||||
res += targetStr.substring(lastIndex, needDealArr[i]) + this.target;
|
||||
lastIndex = needDealArr[i] + this.source.length;
|
||||
}
|
||||
res += targetStr.substring(lastIndex);
|
||||
return res;
|
||||
}
|
||||
|
||||
private dealReg(targetStr: string): string {
|
||||
let templateReg = new RegExp("#\{group(\\d+\)}", "g");
|
||||
let templateArr: string[][] = [];
|
||||
while (true) {
|
||||
let one = templateReg.exec(this.target);
|
||||
if (one == null) {
|
||||
break;
|
||||
}
|
||||
templateArr.push([one[0], one[1]]);
|
||||
}
|
||||
if (changed) {
|
||||
file.originName = file.name;
|
||||
file.expandName = path.extname(file.name);
|
||||
if (file.expandName && file.expandName.length > 0) {
|
||||
file.realName = file.name.substring(0, file.name.lastIndexOf("."));
|
||||
} else {
|
||||
file.realName = file.name;
|
||||
}
|
||||
}
|
||||
|
||||
let reg = new RegExp(this.source, this.regI ? "g" : "ig");
|
||||
let arr: RegExpExecArray[] = [];
|
||||
for (let i = 0; i < (this.type == 1 ? 1 : 1000); i++) {
|
||||
let one = reg.exec(targetStr);
|
||||
if (one == null) {
|
||||
break;
|
||||
}
|
||||
arr.push(one);
|
||||
}
|
||||
if (arr.length == 0) {
|
||||
return targetStr;
|
||||
}
|
||||
let res = "";
|
||||
let needDealReg: RegExpExecArray[] = this.type === 1 ? [arr[0]] : this.type === 2 ? [arr[arr.length - 1]] : arr;
|
||||
let lastIndex = 0;
|
||||
for (let i = 0; i < needDealReg.length; i++) {
|
||||
let reg = needDealReg[i];
|
||||
let target = this.target;
|
||||
templateArr.forEach(item => target = target.replace(item[0], ValUtil.nullToDefault(reg[parseInt(item[1])], '')));
|
||||
res += targetStr.substring(lastIndex, reg.index) + target;
|
||||
lastIndex = reg.index + reg[0].length;
|
||||
}
|
||||
res += targetStr.substring(lastIndex);
|
||||
return res;
|
||||
}
|
||||
}
|
@ -1,6 +1,27 @@
|
||||
import FileObj from "../../vo/FileObj";
|
||||
import * as path from 'path';
|
||||
|
||||
export default interface RuleInterface {
|
||||
|
||||
deal(file: FileObj): void;
|
||||
}
|
||||
|
||||
/**
|
||||
* 重新处理文件名
|
||||
* @param file
|
||||
* @param newFileName
|
||||
* @param ignorePostfix
|
||||
*/
|
||||
export function dealFileName(file: FileObj, newFileName: string, ignorePostfix: boolean) {
|
||||
if (ignorePostfix) {
|
||||
file.realName = newFileName;
|
||||
} else {
|
||||
file.expandName = path.extname(newFileName);
|
||||
if (file.expandName.length > 0) {
|
||||
file.realName = newFileName.substring(0, newFileName.lastIndexOf("."));
|
||||
} else {
|
||||
file.realName = newFileName;
|
||||
}
|
||||
}
|
||||
file.name = file.realName + file.expandName;
|
||||
}
|
@ -3,21 +3,22 @@ import {isVideo, isSub, isNfo} from "../../util/MediaUtil"
|
||||
|
||||
export default class FileObj {
|
||||
/**
|
||||
* 文件名
|
||||
* 变更后的文件名(包含拓展名)
|
||||
*/
|
||||
name: string;
|
||||
/**
|
||||
原始名字
|
||||
* 去掉拓展名后的名字(不包含拓展名)
|
||||
*/
|
||||
realName: string;
|
||||
/**
|
||||
原始文件名(不变)
|
||||
*/
|
||||
originName: string;
|
||||
/**
|
||||
* 拓展名
|
||||
* 拓展名(最新的拓展名,每次应用规则后重新计算)
|
||||
*/
|
||||
expandName: string;
|
||||
/**
|
||||
* 去掉拓展名后的名字
|
||||
*/
|
||||
realName: string;
|
||||
|
||||
/**
|
||||
* 所属路径
|
||||
*/
|
||||
|
8
openRenamerBackend/util/ValUtil.ts
Normal file
8
openRenamerBackend/util/ValUtil.ts
Normal file
@ -0,0 +1,8 @@
|
||||
/**
|
||||
* null to default
|
||||
* @param value
|
||||
* @param defaultVal
|
||||
*/
|
||||
export function nullToDefault(value: any, defaultVal: any): any {
|
||||
return value === undefined || value == null ? defaultVal : value;
|
||||
}
|
9126
openRenamerFront/pnpm-lock.yaml
generated
9126
openRenamerFront/pnpm-lock.yaml
generated
File diff suppressed because it is too large
Load Diff
@ -42,7 +42,7 @@ export default {
|
||||
name: "Home",
|
||||
data() {
|
||||
return {
|
||||
version: "1.7.1",
|
||||
version: "1.8.0",
|
||||
latestVersion: null,
|
||||
activeIndex: location.pathname,
|
||||
showNewVersion: false
|
||||
|
@ -7,37 +7,57 @@
|
||||
<span class="left">目标:</span>
|
||||
<el-input style="width:20em" v-model="ruleObj.data.target" />
|
||||
</div>
|
||||
<div class="flex">
|
||||
<div class="left">正则模式:</div>
|
||||
<el-switch v-model="ruleObj.data.regFlag" />
|
||||
<el-tooltip effect="dark" :content="regTip" placement="right">
|
||||
<el-icon>
|
||||
<InfoFilled />
|
||||
</el-icon>
|
||||
</el-tooltip>
|
||||
</div>
|
||||
<div class="flex">
|
||||
<div class="left">区分大小写:</div>
|
||||
<el-switch v-model="ruleObj.data.regI" />
|
||||
</div>
|
||||
<div class="flex">
|
||||
<span class="left">替换选项:</span>
|
||||
<div class="location">
|
||||
<el-radio v-for="item in radioList" :key="item.code" v-model="ruleObj.data.type" :label="item.code"
|
||||
>{{ item.label }}
|
||||
</el-radio>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
<div class="flex">
|
||||
<div class="left">忽略拓展名:</div>
|
||||
<el-switch v-model="ruleObj.data.ignorePostfix"/>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import { InfoFilled } from "@element-plus/icons-vue";
|
||||
import { nullToDefault } from "@/utils/ValUtil";
|
||||
|
||||
export default {
|
||||
name: "ReplaceRule",
|
||||
components: { InfoFilled },
|
||||
props: ["editRule"],
|
||||
data() {
|
||||
return {
|
||||
regTip: `开启支持js正则匹配,支持分组匹配,目标字符串支持模板#{groupN},N表示匹配到的第几组。比如#{group1}将被替换为匹配到的第一组数据`,
|
||||
radioList: [
|
||||
{
|
||||
label: "替换第一个",
|
||||
code: 1,
|
||||
code: 1
|
||||
},
|
||||
{
|
||||
label: "替换最后一个",
|
||||
code: 2,
|
||||
code: 2
|
||||
},
|
||||
{
|
||||
label: "全部替换",
|
||||
code: 3,
|
||||
},
|
||||
code: 3
|
||||
}
|
||||
],
|
||||
ruleObj: {
|
||||
type: "replace",
|
||||
@ -46,14 +66,20 @@ export default {
|
||||
source: "",
|
||||
target: "",
|
||||
type: 1, //1:替换第一个,2:替换最后一个,3:全部替换
|
||||
},
|
||||
},
|
||||
ignorePostfix: true, //忽略拓展名
|
||||
regFlag: false, //正则模式
|
||||
regI: false //是否区分大小写
|
||||
}
|
||||
}
|
||||
};
|
||||
},
|
||||
created() {
|
||||
if (this.editRule) {
|
||||
console.log(this.editRule);
|
||||
this.ruleObj = JSON.parse(JSON.stringify(this.editRule));
|
||||
//兼容历史数据
|
||||
this.ruleObj.data.ignorePostfix = nullToDefault(this.ruleObj.data.ignorePostfix, true);
|
||||
this.ruleObj.data.regFlag = nullToDefault(this.ruleObj.data.regFlag, false);
|
||||
}
|
||||
},
|
||||
methods: {
|
||||
@ -69,8 +95,8 @@ export default {
|
||||
this.ruleObj.message = `替换:将${this.ruleObj.data.source}替换为${this.ruleObj.data.target};`
|
||||
+ this.radioList.filter(item => item.code === this.ruleObj.data.type)[0].label;
|
||||
return this.ruleObj;
|
||||
},
|
||||
},
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
||||
|
||||
|
9
openRenamerFront/src/utils/ValUtil.js
Normal file
9
openRenamerFront/src/utils/ValUtil.js
Normal file
@ -0,0 +1,9 @@
|
||||
/**
|
||||
* 空转default
|
||||
* @param val
|
||||
* @param defaultVal
|
||||
* @returns {*}
|
||||
*/
|
||||
export function nullToDefault(val, defaultVal) {
|
||||
return val === undefined || val == null ? defaultVal : val;
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user